시간 제한메모리 제한제출정답맞힌 사람정답 비율
0.5 초 (하단 참고)512 MB70331451.852%

문제

Albert는 크기가 n × n 인 2차원 행렬 모양의 게임 보드를 이용한 "소용돌이" 게임을 즐긴다. 편의상 게임 보드의 r행 c열에 해당하는 칸을 (r, c)로 나타내도록 한다.

이 게임 보드의 각 칸에는 영문 대문자 알파벳이 ('A'-'Z') 하나씩 적혀있다. 예를 들어, 아래 그림의 좌측은 크기가 3 x 3인 게임 보드를 나타낸다. (1, 2) 칸에는 "C"가 적혀있고 (3, 1) 칸에는 "G"가 적혀있다.
그림의 우측은 크기가 5 x 5인 게임 보드를 나타낸다. 이 게임 보드의 가장 바깥쪽 칸에는 "A" 혹은 "B"가 적혀있다 (총 16개의 칸이 이에 해당한다). 가장 안쪽에 위치한 칸에는 "Z"가 적혀있다. 나머지 칸에는 "X" 혹은 "Y"가 적혀있다 (총 8개의 칸이 이에 해당한다).

             

구체적으로, n x n인 게임 보드의 "가장 바깥쪽"칸 부터 "가장 안쪽"칸은 아래와 같이 정의한다.

  • 가장 처음이나 마지막 행 혹은 열에 위치한 칸이 "가장 바깥쪽" 칸에 해당한다. 아래 4 x 4와 5 x 5 게임보드에서 "1"로 표시된 칸이 가장 바깥 쪽 칸이다.
  • 가장 바깥쪽 칸을 모두 제외하고 나면 (n-2) x (n-2) 게임 보드가 남게 된다. 위와 마찬가지로 남은 게임 보드에서 가장 처음이나 마지막 행 혹은 열에 위치한 칸이 (두 번째로) 바깥 쪽에 위치한 칸이다. 아래 그림에서 "2"로 표시된 칸이 이에 해당한다.
  • 이와 같이 계속 게임 보드의 안쪽을 향하여 가장 바깥 쪽 부터 가장 안 쪽 칸 까지 정의 할 수 있다.

소용돌이 게임은 아래와 같은 규칙에 따라 한 칸씩 선택하여 총 n2개의 칸을 선택하는 게임이다.

  1. 먼저, 게임 보드의 모서리에 해당하는 (1, 1), (1, n), (n, 1), 혹은 (n, n)중 한 칸을 선택하여 게임을 시작한다. 이후, 모든 칸이 한 번씩 선택될 때 까지 아래 규칙에 따라 게임을 진행한다.
  2. 현재 선택한 칸에서 상/하/좌/우에 인접한 칸 중 하나를 선택하는 것을 반복하되, 아래와 같은 규칙에 따라 선택한다:
    • 규칙 1: 이전에 선택된 칸을 다시 선택할 수 없다.
    • 규칙 2: 규칙 1을 어기지 않으면서 선택할 수 있는 모든 칸 중 게임 보드의 가장 바깥 쪽에 위치한 칸을 선택해야 한다 (그러한 칸이 여럿이라면 그 중 아무 것이나 하나를 선택할 수 있다).

위 규칙을 지키면서 모든 n2개의 칸을 선택하여 얻을 수 있는 (길이가 n2인) 문자열을 "소용돌이 문자열" 이라 부른다.

예를 들어 위의 3 x 3 게임 보드의 경우 아래와 같은 방법으로 소용돌이 문자열을 얻을 수 있다:

  • 턴 1: (1, 1)에서 시작하는 경우:
    • 규칙 1에 따라 다음으로 선택할 수 있는 칸은 (1, 2) 혹은 (2, 1) 뿐이다.
    • 이 둘 모두 가장 게임 보드 가장 바깥 쪽에 위치하므로, 둘 중 어느 것을 선택하여도 된다. 이 예제에서는 (1, 2)를 선택한다.
  • 턴 2: (1, 2)를 선택한 이후:
    • 규칙 1에 따라 다음으로 선택할 수 있는 칸은 (1, 3) 혹은 (2, 2) 뿐이다.
    • 이 두 칸 중 (1, 3)이 (2, 2)보다 더 바깥 쪽에 위치했으므로 규칙 2에 따라 반드시 (1, 3)을 선택해야 한다.
  • 턴 3: (1, 3)을 선택한 이후:
    • 규칙 1에 따라 반드시 (2, 3)을 선택해야 한다.
  • 턴 4-9: (2, 3)을 선택한 이후 상기한 규칙에 따라 반드시 (3, 3), (3, 2), (3, 1), (2, 1), (2, 2)의 순서로 남은 칸을 선택해야 한다.
  • 이 방법을 통해 얻어지는 소용돌이 문자열은 "BCDFIHGEA"가 된다.
  • 만약 턴 2에 (1, 2)가 아닌 (2, 1)을 고를 경우 "BEGHIFDCA"를 얻을 수 있다.

같은 게임 보드에서 (3, 3)에서 시작하는 경우 위와 다른 소용돌이 문자열을 얻을 수 있다:

  • (3, 3) 이후 (3, 2)를 선택하는 경우: "IFDCBEGHA"
  • (3, 3) 이후 (2, 3)을 선택하는 경우: "IHGEBCDFA"

이 외에도 (1, 3) 혹은 (3, 1)에서 시작할 수 있다.

Albert는 임의의 게임 보드를 이용해서 얻을 수 있는 "최대" 소용돌이 문자열과 "최소" 소용돌이 문자열이 무엇인지 궁금하다.
위의 예제의 경우 최대 소용돌이 문자열은 "IHGEBCDFA" 이며 최소 소용돌이 문자열은 "BCDFIHGEA" 이다.

최대 (최소) 소용돌이 문자열은 소용돌이 게임에서 얻을 수 있는 모든 소용돌이 문자열 중 사전순으로 가장 늦게 (먼저) 나오는 문자열이다.

입력

입력 첫 줄에 테스트 케이스의 수 T가 주어진다.

각 테스트 케이스의 첫 줄에 게임 보드의 크기 n이 주어진다.

다음 n줄에 걸쳐 각 줄에 길이 n인 문자열이 주어진다.

출력

각 테스트 케이스의 정답인 최대 소용돌이 문자열과 최소 소용돌이 문자열을 공백으로 구분하여 각 줄에 출력한다.

제한

  • 1 ≤ T ≤ 10
  • 1 ≤ n ≤ 25
  • 게임 보드는 영문 대문자 알파벳 ('A'-'Z')만 포함한다

예제 입력 1

6
3
BCD
EAF
GHI
2
AB
XY
2
GA
GD
4
ABCD
BHAE
CHIF
DEFG
5
LGELG
LGLGE
GGLGE
LGEGL
LGLGL
5
ABABA
BXYXB
AYZYA
BXYXB
ABABA

예제 출력 1

IHGEBCDFA BCDFIHGEA
YXAB ABYX
GGDA ADGG
GFEDCBABCDEFIHHA ABCDEFGFEDCBHAIH
LLGLLGLGLLEEGLEGGLGGGEGGL GEELLGLGLLGLLGELGGGEGGGLL
ABABABABABABABABXYXYXYXYZ ABABABABABABABABXYXYXYXYZ

예제 1: 본문에서 다루었다.

예제 2-5: 추가 설명 없음

예제 6: 본문에서 다룬 예제이다. 이 게임 보드의 경우 모든 소용돌이 문자열이 같다.

[{"problem_id":"23019","problem_lang":"0","title":"\uc18c\uc6a9\ub3cc\uc774","description":"<p>Albert\ub294 \ud06c\uae30\uac00 n &times;&nbsp;n \uc778 2\ucc28\uc6d0 \ud589\ub82c \ubaa8\uc591\uc758 \uac8c\uc784 \ubcf4\ub4dc\ub97c \uc774\uc6a9\ud55c&nbsp;&quot;\uc18c\uc6a9\ub3cc\uc774&quot; \uac8c\uc784\uc744 \uc990\uae34\ub2e4. \ud3b8\uc758\uc0c1 \uac8c\uc784 \ubcf4\ub4dc\uc758 r\ud589 c\uc5f4\uc5d0 \ud574\ub2f9\ud558\ub294 \uce78\uc744 (r, c)\ub85c \ub098\ud0c0\ub0b4\ub3c4\ub85d \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc774 \uac8c\uc784 \ubcf4\ub4dc\uc758 \uac01 \uce78\uc5d0\ub294&nbsp;\uc601\ubb38 \ub300\ubb38\uc790 \uc54c\ud30c\ubcb3\uc774&nbsp;(&#39;A&#39;-&#39;Z&#39;)&nbsp;\ud558\ub098\uc529 \uc801\ud600\uc788\ub2e4. \uc608\ub97c \ub4e4\uc5b4, \uc544\ub798 \uadf8\ub9bc\uc758 \uc88c\uce21\uc740&nbsp;\ud06c\uae30\uac00 3 x 3\uc778 \uac8c\uc784 \ubcf4\ub4dc\ub97c \ub098\ud0c0\ub0b8\ub2e4. (1, 2) \uce78\uc5d0\ub294 &quot;C&quot;\uac00 \uc801\ud600\uc788\uace0 (3, 1) \uce78\uc5d0\ub294 &quot;G&quot;\uac00 \uc801\ud600\uc788\ub2e4.<br \/>\r\n\uadf8\ub9bc\uc758 \uc6b0\uce21\uc740 \ud06c\uae30\uac00 5 x 5\uc778 \uac8c\uc784 \ubcf4\ub4dc\ub97c \ub098\ud0c0\ub0b8\ub2e4. \uc774 \uac8c\uc784 \ubcf4\ub4dc\uc758 <em>\uac00\uc7a5 \ubc14\uae65\ucabd<\/em> \uce78\uc5d0\ub294&nbsp;&quot;A&quot; \ud639\uc740 &quot;B&quot;\uac00 \uc801\ud600\uc788\ub2e4 (\ucd1d 16\uac1c\uc758 \uce78\uc774 \uc774\uc5d0 \ud574\ub2f9\ud55c\ub2e4).&nbsp;<em>\uac00\uc7a5 \uc548\ucabd<\/em>\uc5d0 \uc704\uce58\ud55c \uce78\uc5d0\ub294 &quot;Z&quot;\uac00 \uc801\ud600\uc788\ub2e4. \ub098\uba38\uc9c0 \uce78\uc5d0\ub294 &quot;X&quot;&nbsp;\ud639\uc740 &quot;Y&quot;\uac00 \uc801\ud600\uc788\ub2e4 (\ucd1d 8\uac1c\uc758 \uce78\uc774 \uc774\uc5d0 \ud574\ub2f9\ud55c\ub2e4).<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e8f42741-54cb-4ede-9b2c-48dacb3f8360\/-\/preview\/\" style=\"height: 184px; width: 190px;\" \/>&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;<img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/c4f84957-9514-4dd2-88a1-fb9c8bd5c7ad\/-\/preview\/\" style=\"height: 301px; width: 300px;\" \/><\/p>\r\n\r\n<p>\uad6c\uccb4\uc801\uc73c\ub85c,&nbsp;n x n\uc778 \uac8c\uc784 \ubcf4\ub4dc\uc758 &quot;\uac00\uc7a5 \ubc14\uae65\ucabd&quot;\uce78 \ubd80\ud130 &quot;\uac00\uc7a5 \uc548\ucabd&quot;\uce78\uc740 \uc544\ub798\uc640 \uac19\uc774 \uc815\uc758\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uac00\uc7a5 \ucc98\uc74c\uc774\ub098 \ub9c8\uc9c0\ub9c9 \ud589 \ud639\uc740 \uc5f4\uc5d0 \uc704\uce58\ud55c \uce78\uc774 &quot;\uac00\uc7a5 \ubc14\uae65\ucabd&quot; \uce78\uc5d0 \ud574\ub2f9\ud55c\ub2e4. \uc544\ub798 4 x 4\uc640 5 x 5 \uac8c\uc784\ubcf4\ub4dc\uc5d0\uc11c &quot;1&quot;\ub85c \ud45c\uc2dc\ub41c \uce78\uc774 \uac00\uc7a5 \ubc14\uae65 \ucabd \uce78\uc774\ub2e4.<\/li>\r\n\t<li>\uac00\uc7a5 \ubc14\uae65\ucabd \uce78\uc744 \ubaa8\ub450 \uc81c\uc678\ud558\uace0 \ub098\uba74 (n-2) x (n-2) \uac8c\uc784 \ubcf4\ub4dc\uac00 \ub0a8\uac8c \ub41c\ub2e4. \uc704\uc640 \ub9c8\ucc2c\uac00\uc9c0\ub85c \ub0a8\uc740 \uac8c\uc784 \ubcf4\ub4dc\uc5d0\uc11c \uac00\uc7a5 \ucc98\uc74c\uc774\ub098 \ub9c8\uc9c0\ub9c9 \ud589 \ud639\uc740 \uc5f4\uc5d0 \uc704\uce58\ud55c \uce78\uc774 (\ub450 \ubc88\uc9f8\ub85c) \ubc14\uae65 \ucabd\uc5d0 \uc704\uce58\ud55c \uce78\uc774\ub2e4. \uc544\ub798 \uadf8\ub9bc\uc5d0\uc11c &quot;2&quot;\ub85c \ud45c\uc2dc\ub41c \uce78\uc774 \uc774\uc5d0 \ud574\ub2f9\ud55c\ub2e4.<\/li>\r\n\t<li>\uc774\uc640 \uac19\uc774 \uacc4\uc18d \uac8c\uc784 \ubcf4\ub4dc\uc758 \uc548\ucabd\uc744 \ud5a5\ud558\uc5ec \uac00\uc7a5 \ubc14\uae65 \ucabd \ubd80\ud130 \uac00\uc7a5 \uc548 \ucabd \uce78 \uae4c\uc9c0 \uc815\uc758 \ud560 \uc218 \uc788\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/fdbb0ba7-6427-45f0-8f0e-41b707bbcfc0\/-\/preview\/\" style=\"height: 261px; width: 500px;\" \/><\/p>\r\n\r\n<p>\uc18c\uc6a9\ub3cc\uc774 \uac8c\uc784\uc740 \uc544\ub798\uc640 \uac19\uc740 \uaddc\uce59\uc5d0 \ub530\ub77c&nbsp;\ud55c \uce78\uc529 \uc120\ud0dd\ud558\uc5ec \ucd1d n<sup>2<\/sup>\uac1c\uc758 \uce78\uc744 \uc120\ud0dd\ud558\ub294 \uac8c\uc784\uc774\ub2e4.<\/p>\r\n\r\n<ol>\r\n\t<li>\uba3c\uc800,&nbsp;\uac8c\uc784 \ubcf4\ub4dc\uc758 \ubaa8\uc11c\ub9ac\uc5d0 \ud574\ub2f9\ud558\ub294 (1, 1), (1, n), (n, 1), \ud639\uc740 (n, n)\uc911 \ud55c \uce78\uc744 \uc120\ud0dd\ud558\uc5ec \uac8c\uc784\uc744 \uc2dc\uc791\ud55c\ub2e4. \uc774\ud6c4, \ubaa8\ub4e0 \uce78\uc774 \ud55c \ubc88\uc529 \uc120\ud0dd\ub420 \ub54c \uae4c\uc9c0 \uc544\ub798 \uaddc\uce59\uc5d0 \ub530\ub77c \uac8c\uc784\uc744 \uc9c4\ud589\ud55c\ub2e4.<\/li>\r\n\t<li>\ud604\uc7ac \uc120\ud0dd\ud55c \uce78\uc5d0\uc11c \uc0c1\/\ud558\/\uc88c\/\uc6b0\uc5d0 \uc778\uc811\ud55c \uce78 \uc911 \ud558\ub098\ub97c \uc120\ud0dd\ud558\ub294 \uac83\uc744 \ubc18\ubcf5\ud558\ub418, \uc544\ub798\uc640 \uac19\uc740 \uaddc\uce59\uc5d0 \ub530\ub77c \uc120\ud0dd\ud55c\ub2e4:\r\n\t<ul>\r\n\t\t<li>\uaddc\uce59 1: \uc774\uc804\uc5d0 \uc120\ud0dd\ub41c \uce78\uc744 \ub2e4\uc2dc \uc120\ud0dd\ud560 \uc218 \uc5c6\ub2e4.<\/li>\r\n\t\t<li>\uaddc\uce59 2: \uaddc\uce59 1\uc744 \uc5b4\uae30\uc9c0 \uc54a\uc73c\uba74\uc11c \uc120\ud0dd\ud560 \uc218 \uc788\ub294 \ubaa8\ub4e0 \uce78 \uc911 \uac8c\uc784 \ubcf4\ub4dc\uc758 \uac00\uc7a5&nbsp;\ubc14\uae65 \ucabd\uc5d0 \uc704\uce58\ud55c \uce78\uc744 \uc120\ud0dd\ud574\uc57c \ud55c\ub2e4 (\uadf8\ub7ec\ud55c \uce78\uc774 \uc5ec\ub7ff\uc774\ub77c\uba74 \uadf8 \uc911 \uc544\ubb34 \uac83\uc774\ub098 \ud558\ub098\ub97c \uc120\ud0dd\ud560 \uc218 \uc788\ub2e4).<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ol>\r\n\r\n<p>\uc704&nbsp;\uaddc\uce59\uc744 \uc9c0\ud0a4\uba74\uc11c \ubaa8\ub4e0 n<sup>2<\/sup>\uac1c\uc758 \uce78\uc744&nbsp;\uc120\ud0dd\ud558\uc5ec \uc5bb\uc744 \uc218 \uc788\ub294 (\uae38\uc774\uac00 n<sup>2<\/sup>\uc778) \ubb38\uc790\uc5f4\uc744 &quot;\uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4&quot; \uc774\ub77c \ubd80\ub978\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 \uc704\uc758 3 x 3 \uac8c\uc784 \ubcf4\ub4dc\uc758 \uacbd\uc6b0 \uc544\ub798\uc640 \uac19\uc740 \ubc29\ubc95\uc73c\ub85c \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc744 \uc5bb\uc744 \uc218 \uc788\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>\ud134 1: (1, 1)\uc5d0\uc11c \uc2dc\uc791\ud558\ub294 \uacbd\uc6b0:\r\n\t<ul>\r\n\t\t<li>\uaddc\uce59 1\uc5d0 \ub530\ub77c \ub2e4\uc74c\uc73c\ub85c \uc120\ud0dd\ud560 \uc218 \uc788\ub294 \uce78\uc740 (1, 2) \ud639\uc740 (2, 1) \ubfd0\uc774\ub2e4.<\/li>\r\n\t\t<li>\uc774 \ub458 \ubaa8\ub450 \uac00\uc7a5 \uac8c\uc784 \ubcf4\ub4dc \uac00\uc7a5 \ubc14\uae65 \ucabd\uc5d0 \uc704\uce58\ud558\ubbc0\ub85c, \ub458 \uc911 \uc5b4\ub290 \uac83\uc744 \uc120\ud0dd\ud558\uc5ec\ub3c4 \ub41c\ub2e4. \uc774 \uc608\uc81c\uc5d0\uc11c\ub294 (1, 2)\ub97c \uc120\ud0dd\ud55c\ub2e4.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>\ud134 2: (1, 2)\ub97c \uc120\ud0dd\ud55c \uc774\ud6c4:\r\n\t<ul>\r\n\t\t<li>\uaddc\uce59 1\uc5d0 \ub530\ub77c \ub2e4\uc74c\uc73c\ub85c \uc120\ud0dd\ud560 \uc218 \uc788\ub294 \uce78\uc740 (1, 3) \ud639\uc740 (2, 2) \ubfd0\uc774\ub2e4.<\/li>\r\n\t\t<li>\uc774 \ub450 \uce78 \uc911 (1, 3)\uc774 (2, 2)\ubcf4\ub2e4 \ub354 \ubc14\uae65 \ucabd\uc5d0 \uc704\uce58\ud588\uc73c\ubbc0\ub85c \uaddc\uce59 2\uc5d0 \ub530\ub77c \ubc18\ub4dc\uc2dc (1,&nbsp;3)\uc744 \uc120\ud0dd\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>\ud134 3: (1, 3)\uc744 \uc120\ud0dd\ud55c \uc774\ud6c4:\r\n\t<ul>\r\n\t\t<li>\uaddc\uce59 1\uc5d0 \ub530\ub77c \ubc18\ub4dc\uc2dc (2, 3)\uc744 \uc120\ud0dd\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>\ud134 4-9: (2, 3)\uc744 \uc120\ud0dd\ud55c \uc774\ud6c4 \uc0c1\uae30\ud55c \uaddc\uce59\uc5d0 \ub530\ub77c \ubc18\ub4dc\uc2dc (3, 3), (3, 2), (3, 1), (2, 1), (2, 2)\uc758 \uc21c\uc11c\ub85c \ub0a8\uc740 \uce78\uc744 \uc120\ud0dd\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uc774 \ubc29\ubc95\uc744 \ud1b5\ud574 \uc5bb\uc5b4\uc9c0\ub294 \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc740 &quot;BCDFIHGEA&quot;\uac00 \ub41c\ub2e4.<\/li>\r\n\t<li>\ub9cc\uc57d \ud134 2\uc5d0 (1, 2)\uac00 \uc544\ub2cc (2, 1)\uc744 \uace0\ub97c \uacbd\uc6b0 &quot;BEGHIFDCA&quot;\ub97c \uc5bb\uc744 \uc218 \uc788\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uac19\uc740 \uac8c\uc784 \ubcf4\ub4dc\uc5d0\uc11c (3, 3)\uc5d0\uc11c \uc2dc\uc791\ud558\ub294 \uacbd\uc6b0 \uc704\uc640 \ub2e4\ub978 \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc744 \uc5bb\uc744 \uc218 \uc788\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>(3, 3) \uc774\ud6c4 (3, 2)\ub97c \uc120\ud0dd\ud558\ub294 \uacbd\uc6b0: &quot;IFDCBEGHA&quot;<\/li>\r\n\t<li>(3, 3) \uc774\ud6c4 (2, 3)\uc744 \uc120\ud0dd\ud558\ub294 \uacbd\uc6b0: &quot;IHGEBCDFA&quot;<\/li>\r\n<\/ul>\r\n\r\n<p>\uc774 \uc678\uc5d0\ub3c4 (1, 3) \ud639\uc740 (3, 1)\uc5d0\uc11c \uc2dc\uc791\ud560 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>Albert\ub294 \uc784\uc758\uc758 \uac8c\uc784 \ubcf4\ub4dc\ub97c \uc774\uc6a9\ud574\uc11c \uc5bb\uc744 \uc218 \uc788\ub294 &quot;\ucd5c\ub300&quot; \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uacfc &quot;\ucd5c\uc18c&quot; \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc774 \ubb34\uc5c7\uc778\uc9c0 \uad81\uae08\ud558\ub2e4.<br \/>\r\n\uc704\uc758 \uc608\uc81c\uc758 \uacbd\uc6b0 \ucd5c\ub300 \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc740 &quot;IHGEBCDFA&quot; \uc774\uba70 \ucd5c\uc18c \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc740 &quot;BCDFIHGEA&quot; \uc774\ub2e4.<\/p>\r\n\r\n<p><em>\ucd5c\ub300 (\ucd5c\uc18c) \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc740 \uc18c\uc6a9\ub3cc\uc774 \uac8c\uc784\uc5d0\uc11c \uc5bb\uc744 \uc218 \uc788\ub294 \ubaa8\ub4e0 \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4 \uc911 \uc0ac\uc804\uc21c\uc73c\ub85c \uac00\uc7a5 \ub2a6\uac8c (\uba3c\uc800) \ub098\uc624\ub294 \ubb38\uc790\uc5f4\uc774\ub2e4.<\/em><\/p>\r\n","input":"<p>\uc785\ub825 \uccab \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc218 T\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uccab \uc904\uc5d0 \uac8c\uc784 \ubcf4\ub4dc\uc758 \ud06c\uae30 n\uc774 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\ub2e4\uc74c n\uc904\uc5d0 \uac78\uccd0 \uac01 \uc904\uc5d0 \uae38\uc774 n\uc778 \ubb38\uc790\uc5f4\uc774 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc815\ub2f5\uc778 \ucd5c\ub300 \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uacfc \ucd5c\uc18c \uc18c\uc6a9\ub3cc\uc774&nbsp;\ubb38\uc790\uc5f4\uc744 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ud558\uc5ec \uac01 \uc904\uc5d0 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>1 &le; T &le; 10<\/li>\r\n\t<li>1 &le; n &le; 25<\/li>\r\n\t<li>\uac8c\uc784 \ubcf4\ub4dc\ub294&nbsp;\uc601\ubb38 \ub300\ubb38\uc790 \uc54c\ud30c\ubcb3 (&#39;A&#39;-&#39;Z&#39;)\ub9cc \ud3ec\ud568\ud55c\ub2e4<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>\uc608\uc81c 1: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 2-5: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c<\/p>\r\n\r\n<p>\uc608\uc81c 6: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8ec \uc608\uc81c\uc774\ub2e4. \uc774 \uac8c\uc784 \ubcf4\ub4dc\uc758 \uacbd\uc6b0 \ubaa8\ub4e0 \uc18c\uc6a9\ub3cc\uc774 \ubb38\uc790\uc5f4\uc774 \uac19\ub2e4.<\/p>\r\n"},{"problem_id":"23019","problem_lang":"1","title":"The Swirl Game","description":"<p>Albert often plays the &quot;Swirl&quot; game on a 2D game board&nbsp;of size n x n. In this problem,&nbsp;let (r, c) denote the cell at row r column c.<\/p>\r\n\r\n<p>On every cell of the game board is written&nbsp;one upper-case English alphabet (&#39;A&#39;-&#39;Z&#39;). For instance, a 3 x 3 game board is shown on the left below. Cell (1, 2) has a &quot;C&quot; written on it and (3, 1) has a &quot;G&quot; on it. On the right, a 5 x 5 game board is shown. Its <em>outermost <\/em>cells have either an &quot;A&quot; or a&nbsp;&quot;B&quot; written on them (there are 16 such cells). The <em>innermost<\/em> cell has a &quot;Z&quot; written on it. The remaining cells have either an &quot;X&quot; or a&nbsp;&quot;Y&quot; written on them (there are 8 such cells).<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e8f42741-54cb-4ede-9b2c-48dacb3f8360\/-\/preview\/\" style=\"height: 184px; width: 190px;\" \/>&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;<img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/c4f84957-9514-4dd2-88a1-fb9c8bd5c7ad\/-\/preview\/\" style=\"height: 301px; width: 300px;\" \/><\/p>\r\n\r\n<p>More specifically, we define from &quot;outermost&quot; to &quot;innermost&quot; cells as follows.<\/p>\r\n\r\n<ul>\r\n\t<li>Every cell&nbsp;in the first or last row or in the first or last column is defined&nbsp;&quot;outermost&quot;. In the 4 x 4 and 5 x 5 game boards below, the cells marked with a &quot;1&quot; are outermost cells.<\/li>\r\n\t<li>After removing all outermost cells, we are left with a (n-2) x (n-2) game board. Analogously, we define the (second) outermost cells to be the ones in the first or last&nbsp;row or in the first or last column in this smaller game board. In the example below, the cells marked with &quot;2&quot; are the (second) outermost cells.<\/li>\r\n\t<li>We can repeatedly apply this rule to define the innermost cell(s) as well.<\/li>\r\n<\/ul>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/fdbb0ba7-6427-45f0-8f0e-41b707bbcfc0\/-\/preview\/\" style=\"height: 261px; width: 500px;\" \/><\/p>\r\n\r\n<p>The Swirl game is to choose n<sup>2<\/sup>&nbsp;cells, one at a time, according to the following rules.<\/p>\r\n\r\n<ol>\r\n\t<li>First, Albert chooses one of the four corner cells at&nbsp;(1, 1), (1, n), (n, 1), or (n, n). After this, Albert chooses one cell at a time.<\/li>\r\n\t<li>Albert can choose one of the four adjacent cells of the current cell as the next cell, with the following rules:\r\n\t<ul>\r\n\t\t<li>Rule 1: A cell that&#39;s been previously chosen cannot be chosen again.<\/li>\r\n\t\t<li>Rule 2: Among the cells that Albert can choose without violating Rule 1, an outermost cell must be chosen (in case there are many such cells, any one of them can be chosen).<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ol>\r\n\r\n<p>A Swirl String is a string of length n<sup>2<\/sup> that can be created by choosing n<sup>2<\/sup> cells in the Swirl game.<\/p>\r\n\r\n<p>For instance, in the 3 x 3 game board above, one Swirl string&nbsp;can be obtained as follows:<\/p>\r\n\r\n<ul>\r\n\t<li>Turn 1: Albert starts at cell (1, 1):\r\n\t<ul>\r\n\t\t<li>Due to Rule 1, the next cell must be (1, 2) or (2, 1).<\/li>\r\n\t\t<li>These two cells are equally outermost, so either can be chosen. In this example, suppose Albert chooses (1, 2).<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>Turn 2: Albert chooses (1, 2):\r\n\t<ul>\r\n\t\t<li>Due to Rule 1, either (1, 3) or (2, 2) can be the next cell.&nbsp;<\/li>\r\n\t\t<li>Between the two, (1, 3) is more outer than (2, 2), and thus Rule 2 forces Albert to choose (1, 3).<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>Turn 3: Albert chooses (1, 3):&nbsp;\r\n\t<ul>\r\n\t\t<li>Due to Rule 1, (2, 3) must be chosen next.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>Turn 4-9: After choosing (2, 3), Albert must choose the cells in order of (3, 3), (3, 2), (3, 1), (2, 1), and (2, 2).<\/li>\r\n\t<li>The Swirl string obtained in this example is &quot;BCDFIHGEA&quot;.<\/li>\r\n\t<li>If Albert had chosen (2, 1) instead of (1, 2) in Turn 2, then the Swirl string would have been &quot;BEGHIFDCA&quot;.<\/li>\r\n<\/ul>\r\n\r\n<p>In the same 3 x 3 game board, Albert may also obtain the following strings if he were to begin at (3, 3):<\/p>\r\n\r\n<ul>\r\n\t<li>Choosing (3, 2) after (3, 3): &quot;IFDCBEGHA&quot;<\/li>\r\n\t<li>Choosing (2, 3) after (3, 3): &quot;IHGEBCDFA&quot;<\/li>\r\n<\/ul>\r\n\r\n<p>In addition, Albert could start at (1, 3) or (3, 1).<\/p>\r\n\r\n<p>Albert wants to know the &quot;maximum&quot; Swirl string and the &quot;minimum&quot; Swirl string that he can obtain in an arbitrary game board. In the example above, the maximum Swirl string is&nbsp;&quot;IHGEBCDFA&quot; and the minimum is&nbsp;&quot;BCDFIHGEA&quot;.<\/p>\r\n\r\n<p><em>Maximum (Minimum) Swirl string is the Swirl string that comes lexicographically last (first) among all Swirl strings.<\/em><\/p>\r\n","input":"<p>The first line of the input will contain an integer T, the number of test cases.<\/p>\r\n\r\n<p>For each test case, the first line will contain the size of the game board, n.<\/p>\r\n\r\n<p>The next n lines will contain a string of length n each.<\/p>\r\n","output":"<p>For each test case, output the maximum Swirl&nbsp;string and the minimum Swirl string in a single line,&nbsp;separated by a whitespace.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>1 &le; T &le; 10<\/li>\r\n\t<li>1 &le; n &le; 25<\/li>\r\n\t<li>A game board only contains upper-case English alphabets (&#39;A&#39;-&#39;Z&#39;).<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Case 1: Discussed in the problem statement.<\/p>\r\n\r\n<p>Case 2-5: No&nbsp;explanation provided.<\/p>\r\n\r\n<p>Case 6: Discussed in the problem statement. In this case, all swirl strings are the same.<\/p>\r\n"}]

시간 제한

  • Java 8: 1 초
  • PyPy3: 5 초
  • Java 8 (OpenJDK): 1 초
  • Java 11: 1 초
  • Kotlin (JVM): 1 초
  • Java 15: 1 초