ОБНОВЛЕННАЯ ОЦЕНКА : Поскольку эта задача сложнее, чем я ожидал, я скорректировал оценку. Программа, которая может решить один зеркальный ввод, является правильным ответом. Более сложные программы получают бонус к своему счету.
На PPCG было несколько загадок, чтобы найти лазерный путь в коробке с зеркалами. В этой головоломке вам нужно создать коробку зеркал, чтобы соответствовать целому ряду лазерных направлений.
Вам предоставляется окно и спецификации, где лазеры должны входить и выходить. Ваша программа должна разместить ровно N двухсторонних зеркал в коробке, чтобы соответствовать спецификации. Зеркала должны быть наклонены под углом 45 градусов, но могут быть наклонными вперед или назад.
вход
Ваша программа должна принять блочную сетку через STDIN, аргумент командной строки или файл в следующих примерах формата:
+--G--+ +abcde+
G | f/////d
| /| a// c
+-----+ f |
+-b-e-+
Буквенные пары (можно использовать [a-zA-Z]) указывают на вход / выход до 52 лазеров. Внутри коробки будет N /
зеркал. Размеры поля будут 3 <= W, H <= 200. Поле состоит из +|-
символов. В коробке может быть любое количество зеркал, включая ноль.
Выход
Вывод должен соответствовать вводу, за исключением того, что /
символы могут быть перемещены и / или изменены на \
символы. Ваша программа должна отправлять правильную строку зеркального окна в STDOUT или в файл, после новой строки необязательно. Если никакое размещение зеркал не может соответствовать входной спецификации, выведите Impossible\n
. Примеры возможных решений:
+--G--+ +abcde+
G / | f \ \ d
| | a/ \ c
+-----+ f / //|
+-b-e-+
Пример тестирования
Входные данные:
+abcdefghijklmnopqrstuvwxyA-+
|/////////////// |
|/////////////// |
| |
+-Abcdefghijklmnopqrstuvwxya+
Пример вывода:
+abcdefghijklmnopqrstuvwxyA-+
|\ \|
|/ / |
|\\\\\\\\\\\\\\\\\\\\\\\\\\ |
+-Abcdefghijklmnopqrstuvwxya+
Подсчет очков (ОБНОВЛЕНО)
Это код-гольф с бонусами. Вы должны указать своим ответом, сколько зеркал может решить ваша программа (N). Ваша оценка - это длина вашей программы в байтах, деленная на N. Это позволяет людям войти с простой программой, но вознаграждает больше амбициозных программистов бонусом.
Стандартные лазейки запрещены.
* 2^30
компонент тамОтветы:
C # -
897862 байтаНашел серьезную ошибку при размещении зеркал там, где их не может быть. Теперь это работает, надеюсь! Также немного поиграл в гольф, не мог оставить там время пока ... позорно.
Завершить программу, принимает входные данные из STDIN, выводит в STDOUT.
Это было очень весело, оно отлично справляется с проблемой 7 на 5 (а когда вы убираете одно из зеркал, что делает это невозможным), решение проблемы 30 на 5 заняло около 1 часа.
Пример 7 на 5:
Невозможная версия:
Что-то другое (программа не смотрит на оригинальное зеркальное отображение):
Решение 30 на 5:
Он по очереди смотрит на каждый лазерный источник и строит для него действительный маршрут (если может), а затем переходит к следующему. Это довольно простой поиск в глубину, который должен знать, на какой лазерный источник (цель) он смотрит, сколько зеркал осталось для него разместить, текущую ячейку, в которой он находится, направление, в котором он движется, и каждую ячейку. это уже посещено (так, чтобы это не помещало зеркало, где это уже было). Последние 3 используются для сборки пути для текущей цели и при сбросе при изменении цели. Как только все лазеры подключены, он идет вперед и заполняет все пробелы, которые ему не нужны, оставляя пустыми (еще одна причина, по которой он должен знать, где бы он ни был).
Когда он строит маршруты, он предпочитает идти «вперед», а не вставлять зеркало, а когда он это делает, он предпочитает «\» зеркало - это лучше всего видно в примере «что-то другое» выше, где он пропускает первую ячейку ниже top-most 'a', затем непрерывно заполняет "\", если он может найти решение с одним, в противном случае - "/" (естественно, если пропуск первой ячейки привел к невозможности найти решение, то он вернитесь и попробуйте вместо этого поставить зеркало).
источник
Python,
671654 байтаНе решение, а попытка, читайте ниже.
Я не играл в гольф по максимуму, так как я не удовлетворен решением.
V
проверяет данное решение, обходя полеF
для каждого найденного символаC
в боковой линии. Решения генерируются случайным образом. Это некрасиво, это работает для entry1, но занимает много времени для других записей. Поскольку он случайным образом пытается найти решение, я не считаю это реальным решением данной проблемы; но это может помочь другим.Бегать:
echo "entry1.txt" | python script.py
источник