Вот схема тюрьмы с использованием символов ASCII:
+------------------------------+
| |
| X X |
| |
| D
D |
| |
| |
| X X X |
| |
+------------------------------+
Стены состоят из символов трубы |
, тире -
и столбов +
для углов и пересечений. Есть также две двери, отмеченные D
(которые всегда будут на левой и правой стенах). Тюрьма заполнена страшными людьми с пометкой X
.
Цель состоит в том, чтобы построить стены, чтобы удовлетворить следующие требования:
- Каждый человек находится в одиночном заключении;
- Между двумя дверями проходит коридор;
- Каждая клетка содержит ровно одну дверь, которая напрямую связана с главным коридором;
- Все пространство в тюрьме используется камерами и коридором;
- Каждая ячейка содержит человека (то есть, нет пустых ячеек).
Коридор представляет собой единый путь, не разветвляется и всегда имеет ширину в один символ. Вот решение для тюрьмы выше:
+---------+--------------------+
| | |
| X | X |
| | +--------+
+------D--+-----D-----+ D
D +---D--+
+----D--------+---D-----+ |
| | | |
| X | X |X |
| | | |
+-------------+---------+------+
Вы можете предположить, что любая входная тюрьма всегда будет иметь действительный выход. Вот еще несколько входных тюрем, а также возможные выходы:
+------------------------------+
|X X X X X X X X X X X X X X X |
| |
D D
| |
| X |
+------------------------------+
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+--+
|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X |
+D+D+D+D+D+D+D+D+D+D+D+D+D+D+D-+
D D
+----------------------D-------+
| X |
+------------------------------+
+-----------+
|X |
| |
| |
|X X|
| |
| X|
| |
D D
+-----------+
+-+-------+-+
|X| D |
| D +---+ | |
+-+ | | |
|X| | +---+X|
| | | | +-+
| D | | X|
+-+ | +-D---+
D | D
+---+-------+
+----------------+
|X X X X|
| |
D |
| |
|X X X |
| |
| |
| |
| X X D
| |
| |
+----------------+
+---+---+----+---+
|X | X | X | X|
+--D+--D+---D+--D+
D |
+---+---+------+ |
|X | X | X | |
+--D+--D+---D--+ |
| |
| +-----+------+-+
| | X | X | D
| +----D+---D--+ |
| |
+----------------+