|
Путь спелеолога
(Время: 1 сек. Память: 16 Мб Сложность: 54%)
Пещера представлена кубом, разбитым на N частей по каждому измерению (то есть на N3 кубических клеток). Каждая клетка может быть или пустой, или полностью заполненной камнем. Исходя из положения спелеолога в пещере, требуется найти, какое минимальное количество перемещений по клеткам ему требуется, чтобы выбраться на поверхность. Переходить из клетки в клетку можно, только если они обе свободны и имеют общую грань.
Входные данные
В первой строке входного файла INPUT.TXT содержится число N (1 ≤ N ≤ 30). Далее следует N блоков. Блок состоит из пустой строки и N строк по N символов: # – обозначает клетку, заполненную камнями, точка – свободную клетку. Начальное положение спелеолога обозначено заглавной буквой S. Первый блок представляет верхний уровень пещеры, достижение любой свободной его клетки означает выход на поверхность. Выход на поверхность всегда возможен.
Выходные данные
В выходной файл OUTPUT.TXT выведите одно число – длину пути до поверхности.
Пример
№ | INPUT.TXT | OUTPUT.TXT |
1 | 3
###
###
.##
.#.
.#S
.#.
###
...
### | 6 |
Пояснение к примеру
Нужно спуститься на уровень вниз, сделать два движения на запад, подняться на уровень вверх, сделать движение на юг, подняться на уровень вверх.
Для отправки решения задачи необходимо зарегистрироваться и авторизоваться!
| |