Код Гольф: Вращающийся лабиринт
Сделайте программу, которая берет файл, состоящий из лабиринта. Лабиринт имеет стены, обозначенные #
. Лабиринт должен включать единственный шар, заданный a o
и любое количество отверстий, заданных a @
. Файл лабиринта может быть введен через командную строку или считаться строкой через стандартный ввод. Укажите, что в вашем решении.
Затем ваша программа выполняет следующие действия:
1: If the ball is not directly above a wall, drop it down to the nearest wall.
2: If the ball passes through a hole during step 1, remove the ball.
3: Display the maze in the standard output (followed by a newline).
Extraneous whitespace should not be displayed.
Extraneous whitespace is defined to be whitespace outside of a rectangle
that fits snugly around the maze.
4: If there is no ball in the maze, exit.
5: Read a line from the standard input.
Given a 1, rotate the maze counterclockwise.
Given a 2, rotate the maze clockwise.
Rotations are done by 90 degrees.
It is up to you to decide if extraneous whitespace is allowed.
If the user enters other inputs, repeat this step.
6: Goto step 1.
Вы можете предположить, что все входные лабиринты закрыты. Примечание: отверстие эффективно действует как стена в этом отношении.
Вы можете предположить, что все входные лабиринты не имеют посторонних пробелов.
Побеждает самый короткий исходный код по количеству символов.
Пример, написанный в javascript: http://trinithis.awardspace.com/rotatingMaze/maze.html
Примеры лабиринтов:
######
#o @#
######
###########
#o #
# ####### #
###@ #
#########
###########################
# #
# # @ #
# # # ##
# # ####o####
# # #
# #
# #########
# @
######################