백준 온라인 저지, 구현 / 5373번: 큐빙 (파이썬 / , 백준 플레티넘문제, 삼성 SW 기출문제)

2022. 1. 2. 00:14알고리즘/구현

728x90
반응형

문제

루빅스 큐브는 삼차원 퍼즐이다. 보통 루빅스 큐브는 3×3×3개의 작은 정육면체로 이루어져 있다. 퍼즐을 풀려면 각 면에 있는 아홉 개의 작은 정육면체의 색이 동일해야 한다.

큐브는 각 면을 양방향으로 90도 만큼 돌릴 수 있도록 만들어져 있다. 회전이 마친 이후에는, 다른 면을 돌릴 수 있다. 이렇게 큐브의 서로 다른 면을 돌리다 보면, 색을 섞을 수 있다.

이 문제에서는 루빅스 큐브가 모두 풀린 상태에서 시작한다. 윗 면은 흰색, 아랫 면은 노란색, 앞 면은 빨간색, 뒷 면은 오렌지색, 왼쪽 면은 초록색, 오른쪽 면은 파란색이다.

루빅스 큐브를 돌린 방법이 순서대로 주어진다. 이때, 모두 돌린 다음에 가장 윗 면의 색상을 구하는 프로그램을 작성하시오.

위의 그림은 루빅스 큐브를 푼 그림이다. 왼쪽 면은 시계방향으로 조금 돌려져 있는 상태이다.

입력

첫째 줄에 테스트 케이스의 개수가 주어진다. 테스트 케이스는 최대 100개이다. 각 테스트 케이스는 다음과 같이 구성되어져 있다.

  • 첫째 줄에 큐브를 돌린 횟수 n이 주어진다. (1 ≤ n ≤ 1000)
  • 둘째 줄에는 큐브를 돌린 방법이 주어진다. 각 방법은 공백으로 구분되어져 있으며, 첫 번째 문자는 돌린 면이다. U: 윗 면, D: 아랫 면, F: 앞 면, B: 뒷 면, L: 왼쪽 면, R: 오른쪽 면이다. 두 번째 문자는 돌린 방향이다. +인 경우에는 시계 방향 (그 면을 바라봤을 때가 기준), -인 경우에는 반시계 방향이다.

출력

각 테스트 케이스에 대해서 큐브를 모두 돌린 후의 윗 면의 색상을 출력한다. 첫 번째 줄에는 뒷 면과 접하는 칸의 색을 출력하고, 두 번째, 세 번째 줄은 순서대로 출력하면 된다. 흰색은 w, 노란색은 y, 빨간색은 r, 오렌지색은 o, 초록색은 g, 파란색은 b.

예제 입력 1

4
1
L-
2
F+ B+
4
U- D- L+ R+
10
L- U- L+ U- L- U- U- L+ U+ U+

예제 출력 1

rww
rww
rww
bbb
www
ggg
gwg
owr
bwb
gwo
www
rww
[{"problem_id":"5373","problem_lang":"0","title":"\ud050\ube59","description":"<p>\ub8e8\ube45\uc2a4 \ud050\ube0c\ub294 \uc0bc\ucc28\uc6d0 \ud37c\uc990\uc774\ub2e4. \ubcf4\ud1b5 \ub8e8\ube45\uc2a4 \ud050\ube0c\ub294 3&times;3&times;3\uac1c\uc758 \uc791\uc740 \uc815\uc721\uba74\uccb4\ub85c \uc774\ub8e8\uc5b4\uc838 \uc788\ub2e4. \ud37c\uc990\uc744 \ud480\ub824\uba74 \uac01 \uba74\uc5d0 \uc788\ub294 \uc544\ud649 \uac1c\uc758 \uc791\uc740 \uc815\uc721\uba74\uccb4\uc758 \uc0c9\uc774 \ub3d9\uc77c\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ud050\ube0c\ub294 \uac01 \uba74\uc744 \uc591\ubc29\ud5a5\uc73c\ub85c 90\ub3c4 \ub9cc\ud07c \ub3cc\ub9b4 \uc218 \uc788\ub3c4\ub85d \ub9cc\ub4e4\uc5b4\uc838 \uc788\ub2e4. \ud68c\uc804\uc774 \ub9c8\uce5c \uc774\ud6c4\uc5d0\ub294, \ub2e4\ub978 \uba74\uc744 \ub3cc\ub9b4 \uc218 \uc788\ub2e4. \uc774\ub807\uac8c \ud050\ube0c\uc758 \uc11c\ub85c \ub2e4\ub978 \uba74\uc744 \ub3cc\ub9ac\ub2e4 \ubcf4\uba74, \uc0c9\uc744 \uc11e\uc744 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uc774 \ubb38\uc81c\uc5d0\uc11c\ub294 \ub8e8\ube45\uc2a4 \ud050\ube0c\uac00 \ubaa8\ub450 \ud480\ub9b0 \uc0c1\ud0dc\uc5d0\uc11c \uc2dc\uc791\ud55c\ub2e4. \uc717 \uba74\uc740 \ud770\uc0c9, \uc544\ub7ab \uba74\uc740 \ub178\ub780\uc0c9, \uc55e \uba74\uc740 \ube68\uac04\uc0c9, \ub4b7 \uba74\uc740 \uc624\ub80c\uc9c0\uc0c9, \uc67c\ucabd \uba74\uc740 \ucd08\ub85d\uc0c9, \uc624\ub978\ucabd \uba74\uc740 \ud30c\ub780\uc0c9\uc774\ub2e4.<\/p>\r\n\r\n<p>\ub8e8\ube45\uc2a4 \ud050\ube0c\ub97c \ub3cc\ub9b0 \ubc29\ubc95\uc774 \uc21c\uc11c\ub300\ub85c \uc8fc\uc5b4\uc9c4\ub2e4. \uc774\ub54c, \ubaa8\ub450 \ub3cc\ub9b0 \ub2e4\uc74c\uc5d0 \uac00\uc7a5 \uc717 \uba74\uc758 \uc0c9\uc0c1\uc744 \uad6c\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc2dc\uc624.<\/p>\r\n\r\n<p><img alt=\"\" src=\"\/upload\/images\/cube.png\" style=\"height:120px; width:319px\" \/><\/p>\r\n\r\n<p>\uc704\uc758 \uadf8\ub9bc\uc740 \ub8e8\ube45\uc2a4 \ud050\ube0c\ub97c \ud47c \uadf8\ub9bc\uc774\ub2e4. \uc67c\ucabd \uba74\uc740 \uc2dc\uacc4\ubc29\ud5a5\uc73c\ub85c \uc870\uae08 \ub3cc\ub824\uc838 \uc788\ub294 \uc0c1\ud0dc\uc774\ub2e4.<\/p>\r\n","input":"<p>\uccab\uc9f8 \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uac1c\uc218\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \ucd5c\ub300 100\uac1c\uc774\ub2e4. \uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \ub2e4\uc74c\uacfc \uac19\uc774 \uad6c\uc131\ub418\uc5b4\uc838 \uc788\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uccab\uc9f8 \uc904\uc5d0 \ud050\ube0c\ub97c \ub3cc\ub9b0 \ud69f\uc218 n\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. (1 &le; n &le; 1000)<\/li>\r\n\t<li>\ub458\uc9f8 \uc904\uc5d0\ub294 \ud050\ube0c\ub97c \ub3cc\ub9b0 \ubc29\ubc95\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. \uac01 \ubc29\ubc95\uc740 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4\uc838 \uc788\uc73c\uba70, \uccab \ubc88\uc9f8 \ubb38\uc790\ub294 \ub3cc\ub9b0 \uba74\uc774\ub2e4. U: \uc717 \uba74, D: \uc544\ub7ab \uba74, F: \uc55e \uba74, B: \ub4b7 \uba74, L: \uc67c\ucabd \uba74, R: \uc624\ub978\ucabd \uba74\uc774\ub2e4. \ub450 \ubc88\uc9f8 \ubb38\uc790\ub294 \ub3cc\ub9b0 \ubc29\ud5a5\uc774\ub2e4. +\uc778 \uacbd\uc6b0\uc5d0\ub294 \uc2dc\uacc4 \ubc29\ud5a5 (\uadf8 \uba74\uc744 \ubc14\ub77c\ubd24\uc744 \ub54c\uac00 \uae30\uc900), -\uc778 \uacbd\uc6b0\uc5d0\ub294 \ubc18\uc2dc\uacc4 \ubc29\ud5a5\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0 \ub300\ud574\uc11c \ud050\ube0c\ub97c \ubaa8\ub450 \ub3cc\ub9b0 \ud6c4\uc758 \uc717 \uba74\uc758 \uc0c9\uc0c1\uc744 \ucd9c\ub825\ud55c\ub2e4. \uccab \ubc88\uc9f8 \uc904\uc5d0\ub294 \ub4b7 \uba74\uacfc \uc811\ud558\ub294 \uce78\uc758 \uc0c9\uc744 \ucd9c\ub825\ud558\uace0, \ub450 \ubc88\uc9f8, \uc138 \ubc88\uc9f8 \uc904\uc740 \uc21c\uc11c\ub300\ub85c \ucd9c\ub825\ud558\uba74 \ub41c\ub2e4. \ud770\uc0c9\uc740 w, \ub178\ub780\uc0c9\uc740 y, \ube68\uac04\uc0c9\uc740 r, \uc624\ub80c\uc9c0\uc0c9\uc740 o, \ucd08\ub85d\uc0c9\uc740 g, \ud30c\ub780\uc0c9\uc740 b.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean"},{"problem_id":"5373","problem_lang":"1","title":"Cubing","description":"<p>A Rubik&rsquo;s Cube is a three-dimensional puzzle. In its original version, it is made up of 3\u0002&times;3&times;\u00023 smaller cubes. Each of the visible faces of these smaller cubes has one of six colors (white, yellow, red, orange, green or blue). A Rubik&rsquo;s Cube is said to be solved if on each face, the nine cubes all show the same color.<\/p>\r\n\r\n<p>The Cube is mechanically constructed such that it is possible to rotate any face (that is, any set of 3&times;\u00023 smaller cubes making up one of the six faces of the entire cube) by 90 degrees in both directions. When a rotation is completed, it is again possible to rotate any face in any direction. Thus by combining rotations performed on different faces, it is possible to mix up the colors. The puzzle is then to take a Cube whose colors are mixed up, and return it to its solved state.<\/p>\r\n\r\n<p>We start from a solved Rubik&rsquo;s Cube, which is completely white on the top (up) face, yellow on the bottom (down), red on the front, orange on the back, green on the left and blue on the right. You are given a sequence of rotations. Determine what the top face looks like after applying all rotations.<\/p>\r\n\r\n<p><img alt=\"\" src=\"\/upload\/images\/cube.png\" style=\"height:120px; width:319px\" \/><\/p>\r\n\r\n<p>A solved Rubik&rsquo;s Cube. In the left image the top (white), front (red) and left (green) face are shown. In the right image the same cube is viewed from the opposite side, with the bottom (yellow), back (orange) and right (blue) face visible. Shown is the way in which a face can be rotated (in this case, the left face is partially rotated clockwise).<\/p>\r\n","input":"<p>On the \ufb01rst line one positive number: the number of test cases, at most 100. After that per test case:<\/p>\r\n\r\n<ul>\r\n\t<li>one line with an integer n (1 &le;&nbsp;n &le;&nbsp;1 000): the number of rotations.<\/li>\r\n\t<li>one line with n space-separated pairs of characters: the rotations. For each rotation, the \ufb01rst character identi\ufb01es the face that is rotated: &lsquo;U&rsquo; for the top (up) face, &lsquo;D&rsquo; for the bottom (down), &lsquo;F&rsquo; for the front, &lsquo;B&rsquo; for the back, &lsquo;L&rsquo; for the left and &lsquo;R&rsquo; for the right. The second character indicates the direction of the rotation: &lsquo;+&rsquo; for a clockwise rotation (when looking directly at the face that is rotated), &lsquo;-&rsquo; for a counterclockwise rotation.<\/li>\r\n<\/ul>\r\n","output":"<p>Per test case:<\/p>\r\n\r\n<ul>\r\n\t<li>three lines, each with three characters: the colors of the squares on the top face of the cube, after applying the rotations. The \ufb01rst line corresponds to the squares adjacent to the back side of the cube. The colors are indicated by the \ufb01rst letter (lower case): &lsquo;w&rsquo; for white, &lsquo;y&rsquo; for yellow, &lsquo;r&rsquo; for red, &lsquo;o&rsquo; for orange, &lsquo;g&rsquo; for green and &lsquo;b&rsquo; for blue.<\/li>\r\n<\/ul>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English"}]

접근 방법

- 어떤 면이 돌아갔을 때, 다른 면들이 어떻게 변하는 지를 파악한 뒤, 이를 반영하여 코드를 짠다.
- 1. 왼쪽 면이 돌아갔을 때
- - 시계방향인 경우: 윗면의 왼쪽 열 -> 앞면의 왼쪽 열 -> 아랫면의 왼쪽 열 -> 뒷면의 왼쪽 열 -> 윗면의 왼쪽 열 순으로 바뀐다.
- - 반시계방향인 경우: 윗면의 왼쪽 열 -> 뒷면의 왼쪽 열 -> 아랫면의 왼쪽 열 -> 앞면의 왼쪽 열 -> 윗면의 왼쪽 열 순으로 바뀐다.
- 2. 앞 면이 돌아갔을 때
- - 시계방향인 경우: 윗면의 아래 행 -> 오른쪽면의 왼쪽 열 -> 아랫면의 윗 행 -> 왼쪽면의 오른쪽 열 -> 윗면의 아래 행 순으로 바뀐다.
- - 반시계방향인 경우: 윗면의 아래 향 -> 왼쪽의 오른쪽 열 -> 아랫면의 윗 향 -> 오른쪽면의 왼쪽 열 -> 윗면의 아래 행 순으로 바뀐다.
- 3. 오른쪽 면이 돌아갔을 때
- - 시계방향인 경우: 윗면의 오른쪽 열 -> 뒷면의 오른쪽 열 -> 아랫면의 오른쪽 열 -> 앞면의 오른쪽 열 -> 윗면의 오른쪽 열 순으로 바뀐다.
- - 반시계방향인 경우: 윗면의 오른쪽 열 -> 앞면의 오른쪽 열 -> 아랫면의 오른쪽 열 -> 뒷면의 오른쪽 열 -> 윗면의 오른쪽 열 순으로 바뀐다.
- 4. 윗면이 돌아갔을 때
- - 시계방향인 경우: 왼쪽면의 윗 행 -> 뒷면의 아래행 -> 오른쪽면의 윗 행 -> 앞면의 윗행 순으로 바뀐다.
- - 반시계방향인 경우: 왼쪽면의 윗 행 -> 앞면의 윗 행 -> 오른쪽면의 윗행 -> 뒷면의 아래행 순으로 바뀐다.
- 5. 아래 면이 돌아갔을 때
- - 시계방향인 경우: 앞면의 아래 행 -> 오른쪽의 아래 행 -> 뒷면의 윗 행 -> 왼쪽면의 아래 행 -> 앞면의 아래 행
- - 반시계방향인 경우: 앞면의 아래 행 -> 왼쪽면의 아래행 -> 뒷면의 윗 행 -> 오른쪽면의 아래 행 -> 앞면의 아래 행
- 6. 뒷면이 돌아갔을 떄
- - 시계방향인 경우: 아래면의 아래 행 -> 오른쪽면의 오른쪽 행 -> 윗면의 윗 행 -> 왼쪽면의 왼쪽 행 -> 아래면의 아래 행
- - 반시계방향인 경우: 아래면의 아래 행 -> 왼쪽면의 왼쪽 행 -> 윗면의 윗 행 -> 오른쪽면의 오른쪽 행 -> 아래면의 아래 행

코드

# https://www.acmicpc.net/problem/5373
# 접근 방법
# 어떤 면이 돌아갔을 때, 다른 면들이 어떻게 변하는 지를 파악한 뒤, 이를 반영하여 코드를 짠다.
# 1. 왼쪽 면이 돌아갔을 때
# - 시계방향인 경우: 윗면의 왼쪽 열 -> 앞면의 왼쪽 열 -> 아랫면의 왼쪽 열 -> 뒷면의 왼쪽 열 -> 윗면의 왼쪽 열 순으로 바뀐다.
# - 반시계방향인 경우: 윗면의 왼쪽 열 -> 뒷면의 왼쪽 열 -> 아랫면의 왼쪽 열 -> 앞면의 왼쪽 열 -> 윗면의 왼쪽 열 순으로 바뀐다.
# 2. 앞 면이 돌아갔을 때
# - 시계방향인 경우: 윗면의 아래 행 -> 오른쪽면의 왼쪽 열 -> 아랫면의 윗 행 -> 왼쪽면의 오른쪽 열 -> 윗면의 아래 행 순으로 바뀐다.
# - 반시계방향인 경우: 윗면의 아래 향 -> 왼쪽의 오른쪽 열 -> 아랫면의 윗 향 -> 오른쪽면의 왼쪽 열 -> 윗면의 아래 행 순으로 바뀐다.
# 3. 오른쪽 면이 돌아갔을 때
# - 시계방향인 경우: 윗면의 오른쪽 열 -> 뒷면의 오른쪽 열 -> 아랫면의 오른쪽 열 -> 앞면의 오른쪽 열 -> 윗면의 오른쪽 열 순으로 바뀐다.
# - 반시계방향인 경우: 윗면의 오른쪽 열 -> 앞면의 오른쪽 열 -> 아랫면의 오른쪽 열 -> 뒷면의 오른쪽 열 -> 윗면의 오른쪽 열 순으로 바뀐다.
# 4. 윗면이 돌아갔을 때
# - 시계방향인 경우: 왼쪽면의 윗 행 -> 뒷면의 아래행 -> 오른쪽면의 윗 행 -> 앞면의 윗행 순으로 바뀐다.
# - 반시계방향인 경우: 왼쪽면의 윗 행 -> 앞면의 윗 행 -> 오른쪽면의 윗행 -> 뒷면의 아래행 순으로 바뀐다.
# 5. 아래 면이 돌아갔을 때
# - 시계방향인 경우: 앞면의 아래 행 -> 오른쪽의 아래 행 -> 뒷면의 윗 행 -> 왼쪽면의 아래 행 -> 앞면의 아래 행
# - 반시계방향인 경우: 앞면의 아래 행 -> 왼쪽면의 아래행 -> 뒷면의 윗 행 -> 오른쪽면의 아래 행 -> 앞면의 아래 행
# 6. 뒷면이 돌아갔을 떄
# - 시계방향인 경우: 아래면의 아래 행 -> 오른쪽면의 오른쪽 행 -> 윗면의 윗 행 -> 왼쪽면의 왼쪽 행 -> 아래면의 아래 행
# - 반시계방향인 경우: 아래면의 아래 행 -> 왼쪽면의 왼쪽 행 -> 윗면의 윗 행 -> 오른쪽면의 오른쪽 행 -> 아래면의 아래 행
import sys


def cubing(order, direction):

    # 1. 왼쪽 면이 돌아갔을 때
    # - 시계방향인 경우: 윗면의 왼쪽 열 -> 앞면의 왼쪽 열 -> 아랫면의 왼쪽 열 -> 뒷면의 왼쪽 열 -> 윗면의 왼쪽 열(역) 순으로 바뀐다.
    # - 반시계방향인 경우: 윗면의 왼쪽 열 -> 뒷면의 왼쪽 열(역) -> 아랫면의 왼쪽 열 -> 앞면의 왼쪽 열 -> 윗면의 왼쪽 열 순으로 바뀐다.
    if order == 'L':
        front_, bottom_, back_, top_ = [[0, 0, 0] for _ in range(4)]
        left_ = [[0, 0, 0] for _ in range(3)]
        if direction == '+':
            for i in range(3):
                front_[i], bottom_[i], back_[i], top_[i] = top[i][0], front[i][0], bottom[i][0], back[i][0]
                for j in range(3):
                    left_[j][2-i] = left[i][j]
        else:
            for i in range(3):
                back_[i], bottom_[i], front_[i], top_[i] = top[i][0], back[i][0], bottom[i][0], front[i][0]
                for j in range(3):
                    left_[2-j][i] = left[i][j]

        for i in range(3):
            front[i][0], bottom[i][0], back[i][0], top[i][0] = front_[i], bottom_[i], back_[i], top_[i]
            for j in range(3):
                left[i][j] = left_[i][j]
    # 2. 앞 면이 돌아갔을 때
    # - 시계방향인 경우: 윗면의 아래 행 -> 오른쪽면의 왼쪽 열 -> 아랫면의 윗 행(역) -> 왼쪽면의 오른쪽 열 -> 윗면의 아래 행(역) 순으로 바뀐다.
    # - 반시계방향인 경우: 윗면의 아래 행 -> 왼쪽의 오른쪽 열(역) -> 아랫면의 윗 행 -> 오른쪽면의 왼쪽 열(역) -> 윗면의 아래 행 순으로 바뀐다.
    if order == 'F':
        right_, bottom_, left_, top_ = [[0, 0, 0] for _ in range(4)]
        front_ = [[0, 0, 0] for _ in range(3)]
        if direction == '+':
            for i in range(3):
                right_[i], bottom_[2-i], left_[i], top_[2-i] = top[2][i], right[i][0], bottom[0][i], left[i][2]
                for j in range(3):
                    front_[j][2-i] = front[i][j]
        else:
            for i in range(3):
                left_[2-i], bottom_[i], right_[2-i], top_[i] = top[2][i], left[i][2], bottom[0][i], right[i][0]
                for j in range(3):
                    front_[2-j][i] = front[i][j]

        for i in range(3):
            top[2][i], right[i][0], bottom[0][i], left[i][2] = top_[i], right_[i], bottom_[i], left_[i]
            for j in range(3):
                front[i][j] = front_[i][j]
    # 3. 오른쪽 면이 돌아갔을 때
    # - 시계방향인 경우: 윗면의 오른쪽 열 -> 뒷면의 오른쪽 열(역) -> 아랫면의 오른쪽 열 -> 앞면의 오른쪽 열 -> 윗면의 오른쪽 열 순으로 바뀐다.
    # - 반시계방향인 경우: 윗면의 오른쪽 열 -> 앞면의 오른쪽 열 -> 아랫면의 오른쪽 열 -> 뒷면의 오른쪽 열 -> 윗면의 오른쪽 열(역) 순으로 바뀐다.
    if order == 'R':
        front_, bottom_, back_, top_ = [[0, 0, 0] for _ in range(4)]
        right_ = [[0, 0, 0] for _ in range(3)]
        if direction == '+':
            for i in range(3):
                back_[i], bottom_[i], front_[i], top_[i] = top[i][2], back[i][2], bottom[i][2], front[i][2]
                for j in range(3):
                    right_[j][2-i] = right[i][j]
        else:
            for i in range(3):
                front_[i], bottom_[i], back_[i], top_[i] = top[i][2], front[i][2], bottom[i][2], back[i][2]
                for j in range(3):
                    right_[2-j][i] = right[i][j]
        for i in range(3):
            front[i][2], bottom[i][2], back[i][2], top[i][2] = front_[i], bottom_[i], back_[i], top_[i]
            for j in range(3):
                right[i][j] = right_[i][j]
    # 4. 윗면이 돌아갔을 때
    # - 시계방향인 경우: 왼쪽면의 윗행 -> 뒷면의 아래행(역) -> 오른쪽면의 윗행 -> 앞면의 윗행 -> 왼쪽면의 윗행순으로 바뀐다.
    # - 반시계방향인 경우: 왼쪽면의 윗행 -> 앞면의 윗행 -> 오른쪽면의 윗행 -> 뒷면의 아래행 -> 왼쪽면의 윗행(역)순으로 바뀐다.
    if order == 'U':
        back_, right_, front_, left_ = [[0, 0, 0] for _ in range(4)]
        top_ = [[0,0,0] for _ in range(3)]
        if direction == '+':
            for i in range(3):
                back_[2-i], right_[2-i], front_[i], left_[i] = left[0][i], back[2][i], right[0][i], front[0][i]
                for j in range(3):
                    top_[j][2-i] = top[i][j]
        else:
            for i in range(3):
                front_[i], right_[i], back_[2-i], left_[2-i] = left[0][i], front[0][i], right[0][i], back[2][i]
                for j in range(3):
                    top_[2-j][i] = top[i][j]

        for i in range(3):
            left[0][i], back[2][i], right[0][i], front[0][i] = left_[i], back_[i], right_[i], front_[i]
            for j in range(3):
                top[i][j] = top_[i][j]


    # 5. 아래 면이 돌아갔을 때
    # - 시계방향인 경우: 앞면의 아래 행 -> 오른쪽의 아래 행 -> 뒷면의 윗 행(역) -> 왼쪽면의 아래 행 -> 앞면의 아래 행
    # - 반시계방향인 경우: 앞면의 아래 행 -> 왼쪽면의 아래행 -> 뒷면의 윗 행 -> 오른쪽면의 아래 행(역) -> 앞면의 아래 행
    if order == 'D':
        back_, right_, front_, left_ = [[0, 0, 0] for _ in range(4)]
        bottom_ = [[0,0,0] for _ in range(3)]
        if direction == '+':
            for i in range(3):
                front_[i], right_[i], back_[2-i], left_[2-i] = left[2][i], front[2][i], right[2][i], back[0][i]
                for j in range(3):
                    bottom_[j][2-i] = bottom[i][j]
        else:
            for i in range(3):
                back_[2-i], right_[2-i], front_[i], left_[i] = left[2][i], back[0][i], right[2][i], front[2][i]
                for j in range(3):
                    bottom_[2-j][i] = bottom[i][j]

        for i in range(3):
            left[2][i], back[0][i], right[2][i], front[2][i] = left_[i], back_[i], right_[i], front_[i]
            for j in range(3):
                bottom[i][j] = bottom_[i][j]

    # 6. 뒷면이 돌아갔을 떄
    # - 시계방향인 경우: 아래면의 아래 행 -> 오른쪽면의 오른쪽 행 -> 윗면의 윗 행(역) -> 왼쪽면의 왼쪽 행 -> 아래면의 아래 행(역)
    # - 반시계방향인 경우: 아래면의 아래 행 -> 왼쪽면의 왼쪽 행(역) -> 윗면의 윗 행 -> 오른쪽면의 오른쪽 행(역) -> 아래면의 아래 행
    if order == 'B':
        bottom_, right_, top_, left_ = [[0, 0, 0] for _ in range(4)]
        back_ = [[0,0,0] for _ in range(3)]
        if direction == '+':
            for i in range(3):
                right_[2-i], top_[i], left_[2-i], bottom_[i] = bottom[2][i], right[i][2], top[0][i], left[i][0]
                for j in range(3):
                    back_[j][2-i] = back[i][j]
        else:
            for i in range(3):
                left_[i], top_[2-i], right_[i], bottom_[2-i] = bottom[2][i], left[i][0], top[0][i], right[i][2]
                for j in range(3):
                    back_[2-j][i] = back[i][j]

        for i in range(3):
            bottom[2][i], right[i][2], top[0][i], left[i][0] = bottom_[i], right_[i], top_[i], left_[i]
            for j in range(3):
                back[i][j] = back_[i][j]
    # print(order, direction)
    # print('위:', top)
    # print('왼:', left)
    # print('앞:', front)
    # print('오:', right)
    # print('뒤:', back)
    # print('바닥:', bottom)
    # print()


for tc in range(int(sys.stdin.readline())):
    n = int(sys.stdin.readline())
    orders = list(sys.stdin.readline().split())
    
    top = [['w' for _ in range(3)] for _ in range(3)]
    bottom = [['y' for _ in range(3)] for _ in range(3)]
    front = [['r' for _ in range(3)] for _ in range(3)]
    back = [['o' for _ in range(3)] for _ in range(3)]
    left = [['g' for _ in range(3)] for _ in range(3)]
    right = [['b' for _ in range(3)] for _ in range(3)]

    for i in range(n):
        cubing(orders[i][0], orders[i][1])
    for i in range(3):
        print(top[i][0], top[i][1], top[i][2], sep='')
728x90
반응형