eolymp
bolt
Попробуйте наш новый интерфейс для отправки задач
Задачи

Шифрование робота

Шифрование робота

\includegraphics{https://static.e-olymp.com/content/4f/4f6fec1cf4971805e2ac189f24bf2b32c9db3ad6.jpg} По подозрению в мошенничестве один из параноидальных авторов задач решил шифровать все свои сообщения перед отправкой их другим членам жюри. При этом он не воспользовался стандартными методами шифрования, так как считал, что все они являются гигантской частью заговора по придавлению соревнования IDI Open изнутри. Он считал, что мошенники – самые плохие программисты. И поскольку дешифрование требует определенных навмочек программирования, его можно не бояться. Вместе с закодированным сообщением он отправлял информацию о его дешифровании. Проблема заключалась лишь в том, что все члены жюри могли реализовать декодирование. Вы должны помочь дешифровать сообщения, написав для этого приложение. Дешифрование производится моделированием движения робота на сетке. В начале робот находится в северо-западном углу сетки, лицом повернут к югу. Робот является достаточно простым механизмом, и выполняет только три разных команды: \begin{enumerate} \item \texttt{L} поворачивает работа на \textbf{90°} налево \item \texttt{R} поворачивает работа на \textbf{90°} вправо \item \texttt{F} передвигает работа на одну ячейку вперед. Если в результате перемещения вперед робот упадет с решетки, то вместо перемещения возвращается на \textbf{180°} и не двигается. \end{enumerate} Инструкции о работе подаются в строке в виде набора команд, которые могут содержать циклы. Цикл представляется в виде \texttt{(множество команд)число} где \texttt{число} равно количеству повторений множества команд в скобках, которые должны быть выполнены. Рекурсивно могут быть построены длинные последовательности команд. Более формально: \begin{lstlisting} commandset ::= instruction+ instruction ::= command|loop loop ::= "("commandset")" number command ::= R|L|F number ::= 1|2|3|4|5|6|7|8|9 \end{lstlisting} Дешифрованный текст получается в результате конкатенации символов в ячейках сетки, на которых останавливается робот после выполнения каждой командной строки. \InputFile Первая строка содержит количество тестов $T$ ($0 < T ≤ 100$). Каждый тест начинается строкой, содержащей числа $W$ ($0 < W ≤ 50$) и $H$ ($0 < H ≤ 50$), отделенные одним пропуском и задающие размеры сетки. Далее следует $H$ строк, каждая из которых содержит $W$ символов, описывающих сетку. Следующая строка содержит количество командных строк $N$ ($0 < N ≤ 20$). После него следует $N$ командных строк, которые должны быть выполнены роботом. Командные строки содержат не более $50$ символов и имеют синтаксис, описанный в условии. Символы с ASCII кодом менее $32$ и более $126$ не встречаются на сетке робота. \OutputFile Для каждого теста в отдельной строке выводится дешифрованный текст.
Лимит времени 1 секунда
Лимит использования памяти 64 MiB
Входные данные #1
1
6 7
012345
6789AB
CDEFGH
IJKLMN
OPQRST
UVWXYZ
_! ,&
12
FFL(F)5
(F)4
(LF)2
(L(R)6L)9
RFRFFF
(L(F)2)2
LF
FLFF
FFFF
LF
FLFF
L(F)4
Выходные данные #1
HELLO WORLD!