Школа программиста

Забыли пароль?
[задачи] [курсы] [олимпиады] [регистрация]
Логин:   Пароль:    
Скрыть меню
О школе
Правила
Олимпиады
Фотоальбом
Гостевая
Форум
Архив олимпиад
Архив задач
Состояние системы
Рейтинг
Курсы
Новичкам
Работа в системе
Курсы ККДП
Дистрибутивы
Статьи
Ссылки


 

Конверт

(Время: 1 сек. Память: 16 Мб Сложность: 75%)

Хорошие новости! Межпланетный экспресс запускает новую услугу – теперь компания доставляет не только посылки, но и письма! Письмо - это согнутый несколько раз лист, помещённый в конверт, имеющий прозрачные окошки. Таким образом, часть листа (например, с адресом получателя) видна при закрытом конверте. Линии сгибания листа параллельны и делят лист на одинаковые прямоугольные фрагменты. Тем не менее, единственный в компании специалист по сгибанию Бендер подходит к делу безответственно, иногда допускает ошибки, и в результате напротив прозрачного окошка в конверте может оказаться не тот фрагмент листа. Гермес Конрад хочет избежать ошибок, поэтому, тщательно записывает каждый сделанный сгиб. Теперь ему нужна программа, которая по этим записям вычислит, какие именно фрагменты будут смотреть наружу после проделанных сгибаний.

Бюрократ Гермес придумал следующую систему обозначений: все возможные линии сгибов пронумерованы от 1 до n. Если мы смотрим на лицевую сторону листа и сгибаем «от себя», когда соприкасаются обратные стороны соседних фрагментов листа, а наружу смотрят лицевые стороны, такой сгиб обозначим буквой F (forward/front bend). Если сгибаем «на себя», когда соприкасаются лицевые стороны и наружу показываются обратные стороны – то буквой R (rear bend). Для фрагментов листа нумерация похожая, только с добавлением в начале буквы P, чтобы не перепутать обозначения сгибов и фрагментов: фрагменты письма пронумерованы от P0 до Pn, где сгиб i разделяет фрагменты Pi-1, Pi. Лицевая сторона письма и любого из фрагментов обозначена F (например, P1F), оборотная буквой R (например, P3R)

На иллюстрации, письмо изображается со стороны (лицевая сторона изначально «смотрит» влево, а сгибы изображены как точки). Лицевая сторона обозначается тонкой линией, оборотная – толстой линией, цифрами обозначены точки сгибания, стрелками подписаны некоторые возможные варианты сгибания письма. Размеры сгиба и толщину листа считаем нулевыми, все сгибания выполняются ровно на 180°. Фрагменты после сгибания плотно прилегают друг к другу (в примере просветы после сгибания изображены только для наглядности) – так, во втором примере точки 1 и 3R совмещаются, и фрагмент P0 может обернуться вокруг совмещённых точек. В третьем примере точки 1 и 3 также совмещаются, но при этом фрагмент P0 не может повернуться вокруг 1 – так как ему мешают фрагменты P2, P3. Если Бендер попытается сделать такой сгиб, то такое письмо будет скомкано и выкинуто – это уже работа для уборщика Скраффи.

Входные данные

Входной файл INPUT.TXT содержит одну строку данных, которая начинается с двух чисел: номер наибольшего фрагмента n, 1 ≤ n ≤ 20 (таким образом, письмо имеет n точек сгиба, и n+1 фрагментов с номерами P0, P1 … Pn), количество проделанных сгибаний 1 ≤ m ≤ n (сгибы могут быть сделаны не в каждой возможной точке). Далее выписаны наблюдаемые сгибания через пробел, в порядке их выполнения. Если сгибать бумагу в одной точке несколько раз, то ее прочность теряется, поэтому в каждой точке сгиб производится максимум один раз.

Выходные данные

В выходной файл OUTPUT.TXT выведите перечисление всех видимых фрагментов, в порядке возрастания их номеров, сначала фрагменты стороной F, потом стороны R. Либо слово SCRUFFY, если письмо было скомкано.

Примеры

INPUT.TXTOUTPUT.TXT
13 3 2F 3R 1RP0R P3R
23 3 2F 3R 1FP0F P1F
33 2 2R 1RSCRUFFY
44 2 4F 3FP0F P1F P2F P3F P0R P1R

Для отправки решения задачи необходимо зарегистрироваться и авторизоваться!

[Обсуждение] [Все попытки] [Лучшие попытки]


Красноярский краевой Дворец пионеров, (c)2006 - 2023, E-mail: admin@acmp.ru