Я где-то слышал, что одна вещь, которую технология пока не может сделать, это складывать полотенца 1 . Так что теперь ваша задача - доказать, что это утверждение неверно!
Если в качестве входных данных использовать строку, состоящую из прямоугольников (полотенец), как показано ниже, сложите каждое полотенце пополам дважды. Например:
+------+ +------+ +--+
| | | | | |
| | | | | |
| | -> +------+ -> +--+
| |
| |
| |
+------+
Обратите внимание, что, когда полотенце сложено, оно сначала складывается, затем слева направо. Ваша программа также должна имитировать это поведение. Также обратите внимание, что в тестовых случаях полотенца остаются на одном месте, но сложенными.
Правила:
- Стандартные методы ввода / вывода.
- Применяются стандартные лазейки.
- Ввод и вывод должны быть в виде строки.
- Выходные данные в порядке, если полотенца находятся в нужном месте относительно друг друга.
- Вы можете предположить, что длина каждой стороны полотенца всегда будет делиться на 2.
- Полотенца, переданные на входе, всегда будут прямоугольными.
Полотенца всегда будут отделены друг от друга, однако они могут быть разделены на разные величины.
код-гольф , поэтому выигрывает самый короткий код!
Тестовые случаи:
Input:
+------+
| |
| |
| |
| |
| |
| |
+------+
Output:
+--+
| |
| |
+--+
Input:
+--+ +--+ +--+
| | | | | |
| | | | | |
+--+ +--+ +--+
Output:
++ ++ ++
++ ++ ++
Input:
+----+
| |
| |
| |
| | ++
+----+ ++
Output:
+-+
| |
+-+
+
Input:
+--+
+--+ ++
||
||
++
Output:
++
+
+
1: Это было опровергнуто Геобитсом и Лайкони. Однако я где-то слышал это.
Ответы:
Сетчатка , 245 байт
Попробуйте онлайн!
Примечание: некоторые строки заканчиваются пробелами. Объяснение:
Удалите все остальные строки каждого полотенца (это работает, потому что все полотенца имеют одинаковую высоту),
сдвиньте все отдельные кусочки полотенца вверх,
и закрепите нижнюю часть полотенец, эффективно сложив их.
Сложите полотенца шириной 2 вправо.
Сложите оставшиеся полотенца вправо.
источник
<-2>
это балансирующая группа .NET?(?<-2>.)*
захват каждый раз, поэтому не может повторить больше раз, чем(.)*
сделал, в то время как(?(2)(?!))
проверяет, что не осталось ни одного захвата, чтобы он повторялся столько же раз.Октава с пакетом изображений ,
277272 байтаВход и выход - двумерные массивы символов.
Попробуйте онлайн! Или проверьте все тестовые случаи: 1 , 2 , 3 , 4 . (Обратите внимание, что
endfunction
в тестовых примерах необходимо только отделить функцию от последующего кода. В этом нет необходимости, если функция сохранена в своем собственном файле.)Читаемая версия и объяснение
источник