The 88th Puzzle
Simple+
English

Dr. Emmett Brown: If my calculations are correct, when this baby hits 88 miles per hour... you're gonna see some serious shit.

===

Marty McFly: Hey, Doc, we better back up. We don't have enough road to get up to 88.
Dr. Emmett Brown: Roads? Where we're going, we don't need roads.

"Back to the Future" (1985)

According to ancient Chinese legend, 88 is a magic number. On the 88th page of the book, "Ancient human puzzles catalog for modern robots", you will find a puzzle which Nikola’s archaeologist uncle discovered a very long time ago in an ancient human magazine. Nikola has been trying to solve this puzzle since he first rolled off his parents assembly line, and now it’s time for us to help him figure this out once and for all.

The puzzle looks like four intersecting circles with 12 colored marbles: 2 red, 2 blue, 2 green, 2 orange and 4 grey. Take a look at the illustration to see how this setup works. The marbles should be placed as it shown below. Each hole and color has a number for data representing a state. Colored numbers: 1 - blue, 2 - green, 3 - red, 4 - orange, 0 - grey. The initial state (or completed) will be represented as the sequence of numbers, where an index is a “hole” number:
(1, 2, 1, 0, 2, 0, 0, 3, 0, 4, 3, 4).

You can rotate the rings clockwise. Each move rotates the ring by 90 degrees. The rings are numbered and sequence of action should be represented as a list/tuple of numbers from 1 to 4.

You are given a twisted puzzle state as a tuple of numbers. You should return it to the initial state with the minimal number of steps. For example, the state in the picture below would be represented as (0,2,1,3,2,1,4,0,0,4,0,3) and can be solved in 4 steps "1433" or "4133". The first means "rotate 1st ring one time (by 90 degrees of course), 4th - one time, 3th - two times.

Input: A puzzle state as a tuple of integers.

Output: The shortest solution as a string.

Example:

```puzzle88((0,2,1,3,2,1,4,0,0,4,0,3)) == "1433"
```

How it is used: This is one more puzzle which will show you how you can use computer modeling and simulation to solve an abstract problem - in this case, a combinatorial problem.

Precondition:
len(state) == 12
all(0 ≤ n ≤ 4 for n in state)
All test cases are solvable.

## Become Awesome

• No Ads
• No Limits
• More Content
45
Settings
Code:
Other:
CheckiO Extensions

CheckiO Extensions allow you to use local files to solve missions. More info in a blog post.

In order to install CheckiO client you'll need installed Python (version at least 3.8)

Install CheckiO Client first:

`pip3 install checkio_client`

Configure your tool

`checkio --domain=py config --key=`

Sync solutions into your local folder

`checkio sync`

(in beta testing) Launch local server so your browser can use it and sync solution between local file end extension on the fly. (doesn't work for safari)

`checkio serv -d`

Alternatevly, you can install Chrome extension or FF addon

`checkio install-plugin`
`checkio install-plugin --ff`
`checkio install-plugin --chromium`

Read more here about other functionality that the checkio client provides. Feel free to submit an issue in case of any difficulties.