Draw Ghost Legs

Draw Ghost Legs

The mission is in Blocked Mode. Access to the solutions is blocked for a day or two (even after you share your own), until we'll have enough solutions for you to check. All users who've solved the mission will get the notifications about their opening.

Ghost leg is a well-known method used to get random results. This mechanism has the effect of changing the order in the list.

This mission is almost reversed the Follow Ghost Legs. But this mission has countless answers and asymmetric in difficulty. So You should solve the Follow Ghost Legs first.

example_01 example_02

You are given a list of result for that Ghost leg as input values. The starting value is always sequentially numbered from 1. You have to return the list of legs that match them.

  • The leg is a tuple of two integers, which represent the two vertical lines connected by the leg. (The leg always connects adjacent vertical line).
  • The order of legs represents the level at which they are placed (first leg is the top, and last leg is the bottom).

Your answer will be confirmed by the checker.

Examples:

def checker(func: callable, result: list[int]):
    your_result = [r for r in sorted(result)]
    for a, b in func(result):
        your_result[a - 1], your_result[b - 1] = your_result[b - 1], your_result[a - 1]
    return your_result == result


assert checker(draw_ghost_legs, [3, 2, 1]) is True              # [(1, 2), (2, 3), (1, 2)] etc.
assert checker(draw_ghost_legs, [3, 2, 4, 1]) is True           # [(2, 3), (1, 2), (2, 3), (3, 4)] etc.
assert checker(draw_ghost_legs, [1, 5, 4, 2, 3]) is True        # [(3, 4), (4, 5), (3, 4), (2, 3), (3, 4)] etc.
assert checker(draw_ghost_legs, [2, 3, 4, 5, 6, 1]) is True     # [(1, 2), (2, 3), (3, 4), (4, 5), (5, 6)] etc.

Input: A result of 'Ghost Leg' (a list of integers).

Output: A list of legs (a list of tuple of two integers).

Settings
Code:
Other:
Invalid hot key. Each hot key should be unique and valid
Hot keys:
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.

Pair Programming (Beta-version)

Welcome to Pair Programming! Engage in real-time collaboration on coding projects by starting a session and sharing the provided unique URL with friends or colleagues. This feature is perfect for joint project development, debugging, or learning new skills together. Simply click 'Start Session' to begin your collaborative coding journey!

Waiting for Pair Programming to start...

You are trying to join a pair programming session that has not started yet.

Please wait for the session creator to join.

Waiting for Pair Programming to reconnect...

It looks like the creator of the pair programming session closed the editor window.

It might happen accidentally, so that you can wait for reconnection.

×
 
 
<< <
> >>
exec show

Whats Next?

Free accounts will see Best CheckiO solutions with some delay.
Best Solutions will be opened in a moment
Become Awesome and Don't wait
The next stage is ""
Will be activated in
View More Solutions Random Review Solutions Go to the next mission