파일 업로드

종이접기

profile
실행 시간 제한메모리 제한
1 초512 MB
📃 해결할 문제

정사각형의 종이를 중앙선을 중심으로 접는 방법은 아래 그림에서 보인 것처럼 4가지가 있다.

  • DD: 가로 중심선을 중심으로 반으로 접되 윗 면이 아랫 면을 덮도록 접음
  • UU: 가로 중심선을 중심으로 반으로 접되 아랫 면이 윗 면을 덮도록 접음
  • RR: 세로 중심선을 중심으로 반으로 접되 왼쪽 면이 오른쪽 면을 덮도록 접음
  • LL: 세로 중심선을 중심으로 반으로 접되 오른쪽 면이 왼쪽 면을 덮도록 접음

한 변의 길이가 2k2^k인 정사각형 종이가 있을 때, 이를 세로로 kk번, 가로로 kk번 접으면 (접는 순서는 상관 없음) 각 변의 길이가 1인 정사각형이 된다. 아래 그림에서 보인 것처럼 각 변의 길이가 1인 정사각형의 네 귀퉁이 중 한 군데에 구멍을 낸다. 구멍의 위치는 그림에서 보인 것처럼 숫자로 표시한다.

구멍을 낸 후 접은 순서의 역순으로 종이를 펼치면, 종이에 22k2^{2k}개의 구멍이 있게 된다. 예를 들어, 한 변의 길이가 4(=22)4(= 2^2)인 정사각형을 <RR, DD, DD, RR>순서대로 접은 후, 3번 위치에 구멍을 낸 다음 종이를 펼치면 아래 그림처럼 구멍이 나게 된다.

종이의 크기를 나타내는 정수 kk, 종이를 접는 순서를 나타내는 정보, 구멍 뚫는 위치를 나타내는 정수가 주어질 때, 2k×2k2^k \times 2^k 격자에 뚫린 구멍의 위치를 출력하는 프로그램을 작성하시오.

 

제한사항

  • 1k81 \leq k \leq 8
  • 반드시 가로로 kk번, 세로로 kk번 접는다.
💻 입력

첫 번째 줄에 kk가 주어진다.

다음 줄에는 종이 접는 방법을 나타내는 문자가 2k2k개 주어지는데, 각 문자는 공백으로 구분된다. 종이를 접는 방법 DD, UU, RR, LL은 각각 해당하는 대문자 알파벳으로 주어진다.

다음 줄에는 구멍 뚫는 위치를 나타내는 정수 h(0h3)h(0 \leq h \leq 3) 가 주어진다.

🖨️ 출력

접힌 종이를 접은 순서의 역순으로 펼친 후 정사각형에 뚫린 구멍의 위치를 번호로 출력한다. 출력은 총 2k2k줄로 이루어지며 i(1i2k)i (1 \leq i \leq 2k)번째 줄에는 격자의 ii번 행에 뚫린 구멍의 번호를 왼쪽에서 오른쪽 순서로, 공백을 사이에 두고 출력한다.


💻 예제 입력 1
2
R D D R
3
🖨️ 예제 출력 1
0 1 0 1
2 3 2 3
0 1 0 1
2 3 2 3

출처: KOI 2020 2차대회