시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 512 MB23771314106658.220%

문제

로봇은 명령어를 읽어들여 정사각형 영역 S를 x축 또는 y축과 평행한 방향으로 움직인다. S의 왼쪽 아래 꼭짓점은 (0, 0)이고, 오른쪽 위의 꼭짓점은 (M, M)이다. 처음에 로봇은 (0, 0)에 위치해 있고, 동쪽 방향을 향하고 있다.

명령어는 로봇이 현재 위치에서 행할 동작과 그 동작과 관련된 값으로 주어진다. 동작은 두 가지가 있는데, TURNMOVE이다. TURN 0 명령은 현재 위치에서 왼쪽으로 90도 회전, TURN 1 명령은 현재 위치에서 오른쪽으로 90도 회전을 의미한다. MOVE d 명령은 로봇이 향하고 있는 방향으로 d만큼 움직이는 것을 의미한다. 여기서 d는 양수이다.

명령의 수행 후 로봇이 S의 경계 또는 내부에 있으면 이 명령어는 유효하다. 만일 명령어 수행 후 로봇이 S의 바깥으로 완전히 나가게 된다면 명령어는 유효하지 않다. 일련의 명령어 열을 이루는 각 명령어가 모두 유효하다면, 이 명령어 열을 유효하다고 한다.

예를 들어 로봇이 왼쪽 그림과 같이 (MOVE 6, TURN 0, MOVE 5, TURN 0, MOVE 2, TURN 0, MOVE 2, TURN 0, MOVE 4, TURN 0, MOVE 3, MOVE 2) 명령어를 읽어들인다면, 최종적으로 로봇은 (8, 8) 위치에 있게 된다. 가운데 그림과 같이 (MOVE 10, TURN 0, MOVE 2, TURN 0, MOVE 5, TURN 1, MOVE 5, TURN 1, MOVE 2, TURN 1, MOVE 3, TURN 0, TURN 0, MOVE 6) 명령어를 읽어들인다면, 로봇은 (7, 10)에 위치하게 된다. 오른쪽 그림과 같이 로봇이 S 바깥으로 나간다면, 명령어 열은 유효하지 않다.

그림 1. M = 11일 때 세 가지 명령어 열을 받은 로봇의 경로

한 변의 길이가 M인 정사각형과 n개의 명령어, 그리고 로봇이 (0, 0) 위치에서 시작해 동쪽을 바라보고 있을 때, n개의 명령어를 따라 움직였을 때 최종 위치를 출력하는 프로그램을 작성하라.

입력

입력은 표준 입력으로부터 받는다. 첫 줄에는 두 정수 M과 n (1 ≤ M ≤ 1,000, 1 ≤ n ≤ 1,000)이 주어진다. M은 정사각형 S의 한 변의 길이, 즉 오른쪽 맨 위의 좌표는 (M, M)이 된다. n은 로봇이 수행할 n개의 명령어이다. 그 다음 n개의 줄에는 명령어가 하나씩 주어진다. 각 명령어는 TURNdir 또는 MOVEd의 쌍으로 주어진다. 여기서 dir은 0 또는 1이며 d는 1,000 이하의 양의 정수이다. 로봇의 처음 위치는 (0, 0)이며 동쪽을 바라보고 있음에 유의하라.

출력

표준 출력으로 정확히 한 줄을 출력한다. 명령어 열이 유효하다면 두 음 아닌 정수를 출력하며, 이는 각각 명령어 수행 후 로봇의 위치의 x좌표와 y좌표이고 빈 칸으로 구분되어 있다. 명령어 열이 유효하지 않다면 -1을 출력한다.

예제 입력 1

11 14
MOVE 10
TURN 0
MOVE 2
TURN 0
MOVE 5
TURN 1
MOVE 5
TURN 1
MOVE 2
TURN 1
MOVE 3
TURN 0
TURN 0
MOVE 6

예제 출력 1

7 10

예제 입력 2

11 7
MOVE 5
TURN 0
MOVE 4
TURN 1
MOVE 2
TURN 1
MOVE 5

예제 출력 2

-1

예제 입력 3

2 7
MOVE 2
TURN 0
MOVE 3
TURN 0
MOVE 2
TURN 0
MOVE 2

예제 출력 3

-1
[{"problem_id":"13567","problem_lang":"0","title":"\ub85c\ubd07","description":"<p>\ub85c\ubd07\uc740 \uba85\ub839\uc5b4\ub97c \uc77d\uc5b4\ub4e4\uc5ec&nbsp;\uc815\uc0ac\uac01\ud615 \uc601\uc5ed S\ub97c x\ucd95 \ub610\ub294 y\ucd95\uacfc \ud3c9\ud589\ud55c \ubc29\ud5a5\uc73c\ub85c \uc6c0\uc9c1\uc778\ub2e4. S\uc758 \uc67c\ucabd \uc544\ub798 \uaf2d\uc9d3\uc810\uc740 (0, 0)\uc774\uace0, \uc624\ub978\ucabd \uc704\uc758 \uaf2d\uc9d3\uc810\uc740 (M, M)\uc774\ub2e4. \ucc98\uc74c\uc5d0 \ub85c\ubd07\uc740 (0, 0)\uc5d0 \uc704\uce58\ud574 \uc788\uace0, \ub3d9\ucabd \ubc29\ud5a5\uc744 \ud5a5\ud558\uace0 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uba85\ub839\uc5b4\ub294 \ub85c\ubd07\uc774 \ud604\uc7ac \uc704\uce58\uc5d0\uc11c \ud589\ud560 \ub3d9\uc791\uacfc \uadf8 \ub3d9\uc791\uacfc \uad00\ub828\ub41c \uac12\uc73c\ub85c \uc8fc\uc5b4\uc9c4\ub2e4. \ub3d9\uc791\uc740 \ub450 \uac00\uc9c0\uac00 \uc788\ub294\ub370,&nbsp;<code>TURN<\/code>\uacfc <code>MOVE<\/code>\uc774\ub2e4. <code>TURN 0<\/code> \uba85\ub839\uc740 \ud604\uc7ac \uc704\uce58\uc5d0\uc11c \uc67c\ucabd\uc73c\ub85c 90\ub3c4 \ud68c\uc804, <code>TURN 1<\/code> \uba85\ub839\uc740 \ud604\uc7ac \uc704\uce58\uc5d0\uc11c \uc624\ub978\ucabd\uc73c\ub85c 90\ub3c4 \ud68c\uc804\uc744 \uc758\ubbf8\ud55c\ub2e4. <code>MOVE d<\/code> \uba85\ub839\uc740 \ub85c\ubd07\uc774 \ud5a5\ud558\uace0 \uc788\ub294 \ubc29\ud5a5\uc73c\ub85c d\ub9cc\ud07c \uc6c0\uc9c1\uc774\ub294 \uac83\uc744 \uc758\ubbf8\ud55c\ub2e4. \uc5ec\uae30\uc11c d\ub294 \uc591\uc218\uc774\ub2e4.<\/p>\r\n\r\n<p>\uba85\ub839\uc758 \uc218\ud589 \ud6c4 \ub85c\ubd07\uc774 S\uc758 \uacbd\uacc4 \ub610\ub294 \ub0b4\ubd80\uc5d0 \uc788\uc73c\uba74 \uc774 \uba85\ub839\uc5b4\ub294 \uc720\ud6a8\ud558\ub2e4. \ub9cc\uc77c \uba85\ub839\uc5b4 \uc218\ud589 \ud6c4&nbsp;\ub85c\ubd07\uc774 S\uc758 \ubc14\uae65\uc73c\ub85c \uc644\uc804\ud788 \ub098\uac00\uac8c \ub41c\ub2e4\uba74 \uba85\ub839\uc5b4\ub294 \uc720\ud6a8\ud558\uc9c0 \uc54a\ub2e4. \uc77c\ub828\uc758 \uba85\ub839\uc5b4 \uc5f4\uc744 \uc774\ub8e8\ub294 \uac01 \uba85\ub839\uc5b4\uac00 \ubaa8\ub450 \uc720\ud6a8\ud558\ub2e4\uba74, \uc774 \uba85\ub839\uc5b4 \uc5f4\uc744 \uc720\ud6a8\ud558\ub2e4\uace0 \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 \ub85c\ubd07\uc774 \uc67c\ucabd \uadf8\ub9bc\uacfc \uac19\uc774 (<code>MOVE 6, TURN 0, MOVE 5, TURN 0, MOVE 2, TURN 0, MOVE 2, TURN 0, MOVE 4, TURN 0, MOVE 3, MOVE 2<\/code>) \uba85\ub839\uc5b4\ub97c \uc77d\uc5b4\ub4e4\uc778\ub2e4\uba74, \ucd5c\uc885\uc801\uc73c\ub85c \ub85c\ubd07\uc740 (8, 8) \uc704\uce58\uc5d0 \uc788\uac8c \ub41c\ub2e4. \uac00\uc6b4\ub370 \uadf8\ub9bc\uacfc \uac19\uc774&nbsp;(<code>MOVE 10, TURN 0, MOVE 2, TURN 0, MOVE 5, TURN 1, MOVE 5, TURN 1, MOVE 2, TURN 1, MOVE 3, TURN 0, TURN 0, MOVE 6<\/code>) \uba85\ub839\uc5b4\ub97c \uc77d\uc5b4\ub4e4\uc778\ub2e4\uba74, \ub85c\ubd07\uc740 (7, 10)\uc5d0 \uc704\uce58\ud558\uac8c \ub41c\ub2e4. \uc624\ub978\ucabd \uadf8\ub9bc\uacfc \uac19\uc774 \ub85c\ubd07\uc774 S \ubc14\uae65\uc73c\ub85c \ub098\uac04\ub2e4\uba74, \uba85\ub839\uc5b4 \uc5f4\uc740&nbsp;\uc720\ud6a8\ud558\uc9c0 \uc54a\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img src=\"https:\/\/onlinejudgeimages.s3-ap-northeast-1.amazonaws.com\/userupload\/topology\/20161106\/27f7884c99f7c66d952a1102296b4d62.png\" style=\"height:228px; width:638px\" \/><\/p>\r\n\r\n<p style=\"text-align: center;\">\uadf8\ub9bc 1. M = 11\uc77c \ub54c \uc138 \uac00\uc9c0 \uba85\ub839\uc5b4 \uc5f4\uc744 \ubc1b\uc740 \ub85c\ubd07\uc758 \uacbd\ub85c<\/p>\r\n\r\n<p>\ud55c \ubcc0\uc758 \uae38\uc774\uac00 M\uc778 \uc815\uc0ac\uac01\ud615\uacfc n\uac1c\uc758 \uba85\ub839\uc5b4, \uadf8\ub9ac\uace0 \ub85c\ubd07\uc774 (0, 0) \uc704\uce58\uc5d0\uc11c \uc2dc\uc791\ud574 \ub3d9\ucabd\uc744 \ubc14\ub77c\ubcf4\uace0 \uc788\uc744 \ub54c, n\uac1c\uc758 \uba85\ub839\uc5b4\ub97c \ub530\ub77c \uc6c0\uc9c1\uc600\uc744 \ub54c \ucd5c\uc885 \uc704\uce58\ub97c \ucd9c\ub825\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\ub77c.<\/p>\r\n","input":"<p>\uc785\ub825\uc740 \ud45c\uc900 \uc785\ub825\uc73c\ub85c\ubd80\ud130 \ubc1b\ub294\ub2e4. \uccab \uc904\uc5d0\ub294&nbsp;\ub450 \uc815\uc218 M\uacfc&nbsp;n (1 &le; M &le; 1,000, 1 &le; n &le; 1,000)\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. M\uc740 \uc815\uc0ac\uac01\ud615 S\uc758 \ud55c \ubcc0\uc758 \uae38\uc774, \uc989 \uc624\ub978\ucabd \ub9e8 \uc704\uc758 \uc88c\ud45c\ub294 (M, M)\uc774 \ub41c\ub2e4. n\uc740 \ub85c\ubd07\uc774 \uc218\ud589\ud560 n\uac1c\uc758 \uba85\ub839\uc5b4\uc774\ub2e4. \uadf8 \ub2e4\uc74c n\uac1c\uc758 \uc904\uc5d0\ub294 \uba85\ub839\uc5b4\uac00 \ud558\ub098\uc529 \uc8fc\uc5b4\uc9c4\ub2e4. \uac01 \uba85\ub839\uc5b4\ub294 <code>TURN<\/code>\uacfc <code>dir<\/code> \ub610\ub294 <code>MOVE<\/code>\uc640 <code>d<\/code>\uc758 \uc30d\uc73c\ub85c \uc8fc\uc5b4\uc9c4\ub2e4. \uc5ec\uae30\uc11c <code>dir<\/code>\uc740 0 \ub610\ub294 1\uc774\uba70 <code>d<\/code>\ub294 1,000 \uc774\ud558\uc758 \uc591\uc758 \uc815\uc218\uc774\ub2e4. \ub85c\ubd07\uc758 \ucc98\uc74c \uc704\uce58\ub294 (0, 0)\uc774\uba70 \ub3d9\ucabd\uc744 \ubc14\ub77c\ubcf4\uace0 \uc788\uc74c\uc5d0 \uc720\uc758\ud558\ub77c.<\/p>\r\n","output":"<p>\ud45c\uc900 \ucd9c\ub825\uc73c\ub85c \uc815\ud655\ud788 \ud55c \uc904\uc744 \ucd9c\ub825\ud55c\ub2e4. \uba85\ub839\uc5b4 \uc5f4\uc774 \uc720\ud6a8\ud558\ub2e4\uba74 \ub450 \uc74c \uc544\ub2cc \uc815\uc218\ub97c \ucd9c\ub825\ud558\uba70, \uc774\ub294 \uac01\uac01 \uba85\ub839\uc5b4 \uc218\ud589 \ud6c4 \ub85c\ubd07\uc758 \uc704\uce58\uc758 x\uc88c\ud45c\uc640 y\uc88c\ud45c\uc774\uace0 \ube48 \uce78\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc788\ub2e4. \uba85\ub839\uc5b4 \uc5f4\uc774 \uc720\ud6a8\ud558\uc9c0 \uc54a\ub2e4\uba74 -1\uc744 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean"},{"problem_id":"13567","problem_lang":"1","title":"Robot","description":"<p>A robot receives a series of instructions, and moves in a square region S along the direction parallel to x-axis or y-axis that the instructions tell. The lower left corner of S is (0, 0), and the upper right corner of S is (M, M). Initially, the robot is located at (0, 0), and heads to the east direction.<\/p>\r\n\r\n<p>An instruction is a pair of action and value, where the action is the type that the robot acts at the current robot position, and the value is a parameter with which the robot acts. There are two actions, <code>TURN<\/code> and <code>MOVE<\/code>. The instruction <code>TURN 0<\/code> makes the robot turn 90 degrees to the left at its current position, and <code>TURN 1<\/code> makes the robot turn 90 degrees to the right at its current position. The instruction <code>MOVE d<\/code> makes the robot move d units to the direction the robot currently heads. The distance d is a positive integer.<\/p>\r\n\r\n<p>An instruction is valid if the position that the robot stays after executing the instruction is inside or boundary of S. In other words, the instruction is not valid if it makes the robot leave S completely. A series of the instructions is valid if the instructions are all valid.<\/p>\r\n\r\n<p>We suppose that a robot gets a series of instructions, (<code>MOVE 6<\/code>, <code>TURN 0<\/code>, <code>MOVE 5<\/code>, <code>TURN 0<\/code>, <code>MOVE 2<\/code>, <code>TURN 0<\/code>, <code>MOVE 2<\/code>, <code>TURN 0<\/code>, <code>MOVE 4<\/code>, <code>TURN 0<\/code>, <code>MOVE 3<\/code>, <code>MOVE 2<\/code>) as in the left figure below, then it finally reaches at (8, 8). For another series of the instructions, (<code>MOVE 10<\/code>, <code>TURN 0<\/code>, <code>MOVE 2<\/code>, <code>TURN 0<\/code>, <code>MOVE 5<\/code>, <code>TURN 1<\/code>, <code>MOVE 5<\/code>, <code>TURN 1<\/code>, <code>MOVE 2<\/code>, <code>TURN 1<\/code>, <code>MOVE 3<\/code>, <code>TURN 0<\/code>, <code>TURN 0<\/code>, <code>MOVE 6<\/code>) in the middle figure, the robot will be at (7, 10). However, the final series of the instructions, (<code>MOVE 5<\/code>, <code>TURN 0<\/code>, <code>MOVE 4<\/code>, <code>TURN 1<\/code>, <code>MOVE 2<\/code>, <code>TURN 1<\/code>, <code>MOVE 5<\/code>) in the right figure, makes the robot move out of S, i.e., enter the exterior of S, so this series is not valid.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/onlinejudgeimages.s3-ap-northeast-1.amazonaws.com\/problem\/13567\/1.png\" style=\"height:228px; width:638px\" \/><\/p>\r\n\r\n<p>Figure 1. Three routes of the robot for three different series of instructions where M = 11.<\/p>\r\n\r\n<p>Given a side length M of a square, a series of n (&ge; 1) instructions, and a robot at an initial position (0, 0) of S heading to the east, write a program to output the final position the robot reaches after executing n instructions one by one.<\/p>\r\n","input":"<p>Your program is to read from standard input. The input starts with a line containing two integers, M and n (1 &le; M &le; 1,000, 1 &le; n &le; 1,000), where M is the side length of the square S, i.e., its upper right corner has coordinates (x, y) = (M, M), and n is the number of instructions the robot will execute. Each of the following n lines contains a single instruction. Each instruction is represented by a pair of <code>TURN<\/code> and <code>dir<\/code> or by a pair of <code>MOVE<\/code> and <code>d<\/code>, where <code>dir<\/code> is 0 or 1 and <code>d<\/code> is a positive integer no more than 1,000. Note that the robot is initially at (0, 0) of S and heads to the east direction.<\/p>\r\n","output":"<p>Your program is to write to standard output. Print exactly one line. If the series of the instructions given in the input is valid, the line should contain two non-negative integers, which are x-coordinate and y-coordinate, separated by a space, of the position that the robot reaches just after executing all the instructions. If the series is not valid, then the line should contain a single integer -1.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English"}]

출처

ICPC > Regionals > Asia Pacific > Korea > Asia Regional - Daejeon 2016 I번