Каждый программист знает, что скобки []{}()<>
- это действительно весело. Чтобы усугубить это удовольствие, группы переплетенных скобок могут быть преобразованы в симпатичные и нечеткие диаграммы.
Допустим, у вас есть строка, которая содержит сбалансированные скобки, например [{][<(]})>(())
. Шаг первый - повернуть струну на 45 градусов по часовой стрелке. (В Mathematica это можно сделать почти с помощью Rotate[ur_string,-pi/4]
). Вот результат первого шага:
[
{
]
[
<
(
]
}
)
>
(
(
)
)
Затем добавьте диагональный пробел между каждым символом.
[
{
]
[
<
(
]
}
)
>
(
(
)
)
Затем начните с самой левой скобки и нарисуйте квадрат между ним и его партнером по преступлению.
+---+
| |
| { |
| |
+---+
[
<
(
]
}
)
>
(
(
)
)
Повторите этот процесс с каждой парой скобок, перезаписывая предыдущие символы с +
s, если это необходимо.
+---+
| |
| +-+---------+
| | | |
+-+-+ |
| |
| [ |
| |
| < |
| |
| ( |
| |
| ] |
| |
+-----------+
)
>
(
(
)
)
Продолжайте, пока не сделаете все красиво и четко.
+---+
| |
| +-+---------+
| | | |
+-+-+ |
| |
| +-----+ |
| | | |
| | +---+-+---+
| | | | | |
| | | +-+-+-+ |
| | | | | | | |
| +-+-+-+ | | |
| | | | | |
+-----+-+---+ | |
| | | |
| +-----+ |
| |
+---------+
+-----+
| |
| +-+ |
| | | |
| +-+ |
| |
+-----+
вход
Вводом будет одна строка сбалансированных скобок и никаких других символов, причем каждая скобка является одной из []{}()<>
. Каждый тип скобок сбалансирован индивидуально, хотя разные типы могут перекрываться (это то, что делает квадраты интересными). Завершающий перевод строки не является обязательным.
Выход
Выходными данными будет квадратный шаблон блокировки, созданный из строки скобок. Завершающие пробелы и завершающие символы новой строки являются необязательными, но не должно быть начальных пробелов.
Цель
Это код-гольф, побеждает меньше байтов.
[[]]
можем ли мы вывести два квадрата с наложением или мы должны вывести один квадрат внутри другого?