Коробки ASCII выглядят так:
++ +---+ +------+ +---+ +---+
++ | | | | | | | |
| | | | | | | |
+-+ | | | | | | | |
+-+ | | | | | | +---+
+---+ | | | |
+--+ | | | | ++
| | | | | | ||
| | +------+ | | ||
+--+ | | ||
+---+ ||
||
+-----+ ||
+------------+ | | ++
| | | |
| | | |
+------------+ +-----+
Вот несколько примеров таких же ASCII-блоков:
++ +- -+ +- -+ +- -+ +- -+
++ | - | | - - | | - | | - |
| | | -- | | | | |
+-+ | | | | " | - |
+-+ | - | || | | +- -+
+- -+ | | | |
+--+ | -- | | | ++
| | | - - | " ||
| | +- -+ | | ||
+--+ | - | | |
+- -+ | |
-- ||
- - +- -+ ||
+- - - -+ | - - | ++
| -- -- | | = |
| -- -- | | - - |
+- - - -+ +- -+
- -
--
Вот ссылка на все эти блоки тестовых примеров в более удобном для копирования формате. Порядок - все входы, за которыми следуют все выходы в одинаковом порядке.
Ваша цель - взять ASCII-бокс в качестве входных данных и вернуть взорванный бокс. Правила взрыва:
- «+» никогда не меняется; ни "-", ни "|" непосредственно рядом с "+"
- Начиная с углов, «-» и «|» переместиться внутрь на один пробел больше, чем сделал тот же персонаж ближе к углу. Если "-" и "|" никогда не будет двигаться в том же месте, ни один не движется.
- Если «-» и «-» перемещаются в одно и то же место, поместите «=» в это место. Если "|" и "|" переместитесь в то же место, поставьте «в этом месте». Они считаются двумя соответствующими персонажами в одном и том же месте, которые движутся в противоположных направлениях.
- Два "-" или два "|" может двигаться мимо друг друга, как видно в нижнем левом примере.
- Если коробка достаточно тонкая, она начнет расширяться наружу таким же образом, всегда удаляясь от той стороны, с которой она начала.
- Результат должен быть симметричным относительно центральной линии в направлениях x и y (игнорируя новые строки); это включает пробелы, поэтому для удовлетворения этого результата может потребоваться заполнить пробелами.
Детали правила:
- Это код-гольф, поэтому выигрывает самая короткая программа в байтах.
- Применяются стандартные лазейки.
- Вы можете предположить, что каждая строка заканчивается символом новой строки.
- Единственными символами во входной строке будут «+», «-», «|», «» и «\ n» (новая строка), и ваша выходная строка должна следовать тем же правилам с добавлением «=» и "как возможные персонажи.
- При желании у вас может быть один завершающий символ новой строки в конце последней строки.
- Наименьшее поле ASCII, которое вам нужно обработать, - это левый верхний пример. Каждая коробка ASCII будет иметь ровно 4 "+", точно по углам.
- Вам нужно будет обрабатывать поля размера
m x n
для любых целых чисел,m,n
таких что2<=m,n<256
(максимально возможный размер строки255*(255+1)
) - Вы можете предположить, что вы всегда получите один действительный ASCII-блок в качестве ввода.
||
в этом примере должен быть"
или что-то ..."
хотя? Я думаю, что"
только появляется на 3-шириной или больше?"
пойдет? Слева или справа? Это не может быть и то и другое, но не может быть и так, потому что результат симметричен.Ответы:
Python 2 ,
591555545527525496436351334333303 байтаПопробуйте онлайн!
РЕДАКТИРОВАТЬ : мой старый метод сначала взорвался сверху и снизу, а затем влево и вправо. Вместо этого мы можем взорвать вершину, повернуть на 90 градусов и сделать это 4 раза. Кроме того, я использовал удобный код, который требует ввода в форме,
[['+', '-', '-', '-', '-', '-', '+'], ['|', ' ', ' ', ' ', ' ', ' ', '|'], ['|', ' ', ' ', ' ', ' ', ' ', '|'], ['|', ' ', ' ', ' ', ' ', ' ', '|'], ['+', '-', '-', '-', '-', '-', '+']]
которая уродлива, но короче для программы: P (Спасибо Phoenix за то, что поймал это)Кредиты Leaky Nun для кода заголовка в ссылке TIO, используемой для преобразования читабельного ввода человеком в читаемый компьютером ввод.
-85 байт благодаря Лики Нун!
-17 байт путем переключения с верхней имплозии на левую имплозию, что позволяет хранить всю строку в переменной и изменять ее. Спасибо Leaky Nun за предложение!
-1 байт, переключая вещи, чтобы удалить пробел.
-30 байт благодаря Лики Нун!
источник
s[0]
иS[0]
переменным, чтобы сохранить несколько байтовp=s[0]
иP=S[0]
сp=z(s[0])
иP=z(S[0])
, соответственно, а затем заменить все вхожденияz(p)
сp
и всеz(P)
с ,P
чтобы сэкономить 18 байт.(z(s)-1)/2-p
сz(s)/2-.5-p
и(p-1)/2-z(s)
с ,p/2-.5-z(s)
чтобы сохранить больше 2 байта.C (лязг) , 693 байта
Новые строки добавлены для удобства чтения. Первые два обязательны, а остальные нет.
Спасибо за большой вызов! Это было довольно сложно, но мне все равно было очень весело.
Он принимает входные данные в качестве аргументов командной строки и выводит в STDOUT многострочную строку развернутого блока. Как всегда, советы по игре в гольф очень ценятся.
Попробуйте онлайн!
источник