시간 제한 메모리 제한 제출 정답 맞은 사람 정답 비율
1 초 128 MB 53 14 12 31.579%

문제

상근기업(SK)은 최신 기술을 모두 이용해서 새로운 계산기 SK CXX를 만들었다. 이 계산기는 I부터 MMMMCMXCIX까지 정수에 대해서 사칙연산을 지원한다.

이 문제는 SK CXX를 시뮬레이팅 하는 문제이다. 입력의 각 줄은 양의 정수(I(1) ~ MMMMCMXCIX(4999))의 로마 숫자 표기법 또는 사칙 연산자 (+ - * /)이다. 숫자는 스택의 가장 위에 push되고, 연산자는 스택의 가장 위의 2값을 계산한다. 그리고, = 연산자는 스택의 가장 위에 있는 값을 로마 숫자로 출력한다.

- 연산의 경우에는, 첫 번째 숫자를 두 번째 숫자에서 빼는 것이고, / 연산은 두 번째 숫자를 첫 번째 숫자로 나누는 것이다. 만약 0으로 나눌 경우에는 "division by zero exception"을 출력한 뒤, 피제수(0이 아닌 값)를 스택에 저장한고, 제수(0)는 저장하지 않는다.

만약, +, -, *, /, =연산을 수행해야 하는데, 스택에 충분한 숫자가 없을 때는 "stack underflow"를 출력한 뒤, 연산을 수행하지 않는다. 또, 출력해야 하는 숫자가 0보다 작거나 같거나, MMMMCMXCIX(4999)보다 크다면, "out of range exception"을 출력한 뒤, 다음 입력을 수행한다.

로마 숫자 표기법은 2608번에 잘 설명되어 있다.

입력

입력은 여러 줄로 이루어져 있고, 다음 2가지 중 하나이다.

- 로마 숫자 표현 I부터 MMMMCMXCIX까지

- 산술 연산 +, -, /, * 또는, 출력 연산 =

입력은 파일의 끝에서 끝난다.

출력

입력으로 = 연산이 주어질 때 마다 스택의 가장 위에 있는 값을 출력한다. 또는, 에러가 발생했을 경우 에러를 출력한다.

예제 입력 1

I
I
+
=
II
*
=
VIII
-
=

예제 출력 1

II
IV
out of range exception
[{"problem_id":"4773","problem_lang":"0","title":"\ub85c\ub9c8 \uc22b\uc790 \uacc4\uc0b0\uae30","description":"<p>\r\n\t\uc0c1\uadfc\uae30\uc5c5(SK)\uc740 \ucd5c\uc2e0 \uae30\uc220\uc744 \ubaa8\ub450 \uc774\uc6a9\ud574\uc11c \uc0c8\ub85c\uc6b4 \uacc4\uc0b0\uae30 SK CXX\ub97c \ub9cc\ub4e4\uc5c8\ub2e4. \uc774 \uacc4\uc0b0\uae30\ub294 I\ubd80\ud130 MMMMCMXCIX\uae4c\uc9c0 \uc815\uc218\uc5d0 \ub300\ud574\uc11c \uc0ac\uce59\uc5f0\uc0b0\uc744 \uc9c0\uc6d0\ud55c\ub2e4.<\/p>\r\n\r\n<p>\r\n\t\uc774 \ubb38\uc81c\ub294 SK CXX\ub97c \uc2dc\ubbac\ub808\uc774\ud305 \ud558\ub294 \ubb38\uc81c\uc774\ub2e4. \uc785\ub825\uc758 \uac01 \uc904\uc740 \uc591\uc758 \uc815\uc218(I(1) ~ MMMMCMXCIX(4999))\uc758 \ub85c\ub9c8 \uc22b\uc790 \ud45c\uae30\ubc95 \ub610\ub294 \uc0ac\uce59 \uc5f0\uc0b0\uc790 (+ - * \/)\uc774\ub2e4. \uc22b\uc790\ub294 \uc2a4\ud0dd\uc758 \uac00\uc7a5 \uc704\uc5d0 push\ub418\uace0, \uc5f0\uc0b0\uc790\ub294 \uc2a4\ud0dd\uc758 \uac00\uc7a5 \uc704\uc758 2\uac12\uc744 \uacc4\uc0b0\ud55c\ub2e4. \uadf8\ub9ac\uace0, = \uc5f0\uc0b0\uc790\ub294 \uc2a4\ud0dd\uc758 \uac00\uc7a5 \uc704\uc5d0 \uc788\ub294 \uac12\uc744 \ub85c\ub9c8 \uc22b\uc790\ub85c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<p>\r\n\t- \uc5f0\uc0b0\uc758 \uacbd\uc6b0\uc5d0\ub294, \uccab \ubc88\uc9f8 \uc22b\uc790\ub97c \ub450 \ubc88\uc9f8 \uc22b\uc790\uc5d0\uc11c \ube7c\ub294 \uac83\uc774\uace0, \/ \uc5f0\uc0b0\uc740 \ub450 \ubc88\uc9f8 \uc22b\uc790\ub97c \uccab \ubc88\uc9f8 \uc22b\uc790\ub85c \ub098\ub204\ub294 \uac83\uc774\ub2e4. \ub9cc\uc57d 0\uc73c\ub85c \ub098\ub20c \uacbd\uc6b0\uc5d0\ub294 &quot;division by zero exception&quot;\uc744 \ucd9c\ub825\ud55c \ub4a4, \ud53c\uc81c\uc218(0\uc774 \uc544\ub2cc \uac12)\ub97c \uc2a4\ud0dd\uc5d0 \uc800\uc7a5\ud55c\uace0, \uc81c\uc218(0)\ub294 \uc800\uc7a5\ud558\uc9c0 \uc54a\ub294\ub2e4.<\/p>\r\n\r\n<p>\r\n\t\ub9cc\uc57d, +, -, *, \/, =\uc5f0\uc0b0\uc744 \uc218\ud589\ud574\uc57c \ud558\ub294\ub370, \uc2a4\ud0dd\uc5d0 \ucda9\ubd84\ud55c \uc22b\uc790\uac00 \uc5c6\uc744 \ub54c\ub294 &quot;stack underflow&quot;\ub97c \ucd9c\ub825\ud55c \ub4a4, \uc5f0\uc0b0\uc744 \uc218\ud589\ud558\uc9c0 \uc54a\ub294\ub2e4. \ub610, \ucd9c\ub825\ud574\uc57c \ud558\ub294 \uc22b\uc790\uac00 0\ubcf4\ub2e4 \uc791\uac70\ub098 \uac19\uac70\ub098, MMMMCMXCIX(4999)\ubcf4\ub2e4 \ud06c\ub2e4\uba74, &quot;out of range exception&quot;\uc744 \ucd9c\ub825\ud55c \ub4a4, \ub2e4\uc74c \uc785\ub825\uc744 \uc218\ud589\ud55c\ub2e4.<\/p>\r\n\r\n<p>\r\n\t\ub85c\ub9c8 \uc22b\uc790 \ud45c\uae30\ubc95\uc740 <a href=\"http:\/\/www.acmicpc.net\/problem\/2608\">2608\ubc88<\/a>\uc5d0 \uc798 \uc124\uba85\ub418\uc5b4 \uc788\ub2e4.<\/p>\r\n","input":"<p>\r\n\t\uc785\ub825\uc740 \uc5ec\ub7ec \uc904\ub85c \uc774\ub8e8\uc5b4\uc838 \uc788\uace0, \ub2e4\uc74c 2\uac00\uc9c0 \uc911 \ud558\ub098\uc774\ub2e4.<\/p>\r\n\r\n<p>- \ub85c\ub9c8 \uc22b\uc790 \ud45c\ud604 I\ubd80\ud130 MMMMCMXCIX\uae4c\uc9c0<\/p>\r\n<p>- \uc0b0\uc220 \uc5f0\uc0b0 +, -, \/, * \ub610\ub294, \ucd9c\ub825 \uc5f0\uc0b0 =<\/p>\r\n\r\n<p>\r\n\t\uc785\ub825\uc740 \ud30c\uc77c\uc758 \ub05d\uc5d0\uc11c \ub05d\ub09c\ub2e4.<\/p>\r\n","output":"<p>\r\n\t\uc785\ub825\uc73c\ub85c = \uc5f0\uc0b0\uc774 \uc8fc\uc5b4\uc9c8 \ub54c \ub9c8\ub2e4 \uc2a4\ud0dd\uc758 \uac00\uc7a5 \uc704\uc5d0 \uc788\ub294 \uac12\uc744 \ucd9c\ub825\ud55c\ub2e4. \ub610\ub294, \uc5d0\ub7ec\uac00 \ubc1c\uc0dd\ud588\uc744 \uacbd\uc6b0 \uc5d0\ub7ec\ub97c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"0","problem_lang_code":"\ud55c\uad6d\uc5b4"},{"problem_id":"4773","problem_lang":"1","title":"Reverse Roman Notation","description":"<p>Hermes Poseidon (HP) has produced a new calculator, the HP CXX, using the very latest in modern technology. It supports the four basic arithmetic operations on integer values from I to MMMMCMXCIX.<\/p>\r\n\r\n<p>In this problem, you are simulating The HP CXX. Each line of input will be either a roman numeral representation of a positive integer (between I(1) and MMMMCMXCIX(4999)), which will then be pushed to the top of the virtual stack, or it will be an arithmetic operation (+ &minus; * \/) to be performed on the top two values of the stack. In addition, there is the = operation, which is a request to print the value of the top of the stack (in roman numerals, of course).<\/p>\r\n\r\n<p>For the &minus; operation, subtract the \ufb01rst number on the stack from the second. For \/, divide the second number on the stack by the \ufb01rst. An attempt to divide by 0 should result in the error message &ldquo;division by zero exception&rdquo;. When that happens, push the dividend (non-zero number) back onto the stack, but not the divisor (zero).<\/p>\r\n\r\n<p>If an operation is requested, and there are insuf\ufb01cient numbers on the stack, print the error &ldquo;stack under\ufb02ow&rdquo; and leave the stack unchanged. This applies to both the binary operations +&minus;*\/ and the print operation =.<\/p>\r\n\r\n<p>If an attempt is made to print a number whose value is 0 or less, or whose value is greater than MMMMCMXCIX(4999), display the error message &ldquo;out of range exception&rdquo; and go on to the next line of input.<\/p>\r\n\r\n<p>Roman Numerals<\/p>\r\n\r\n<p>For those who are unfamiliar with Roman Numerals, here is a quick summary:<\/p>\r\n\r\n<p>Each letter used in Roman numerals stands for a different number:<\/p>\r\n\r\n<table class=\"table\" style=\"width:30%\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th style=\"width:15%\">Roman Numeral<\/th>\r\n\t\t\t<th style=\"width:15%\">Number<\/th>\r\n\t\t<\/tr>\r\n\t<\/thead>\r\n\t<tbody>\r\n\t\t<tr>\r\n\t\t\t<td>I<\/td>\r\n\t\t\t<td>1<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>V<\/td>\r\n\t\t\t<td>5<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>X<\/td>\r\n\t\t\t<td>10<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>L<\/td>\r\n\t\t\t<td>50<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>C<\/td>\r\n\t\t\t<td>100<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>D<\/td>\r\n\t\t\t<td>500<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>M<\/td>\r\n\t\t\t<td>1000<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>A string of letters means that their values should be added together. For example, XXX = 10 + 10 + 10 = 30, and LXI = 50 + 10 + 1 = 61. If a smaller value is placed before a larger one, we subtract instead of adding. For instance, IV = 5 &minus; 1 = 4 and XC = 100 &minus; 10 = 90.<\/p>\r\n\r\n<ul>\r\n\t<li>Except for M, do not add more than three of the same letters together.<\/li>\r\n\t<li>Subtract only powers of ten, such as I, X, or C. Writing VL for 45 is not allowed: write XLV instead.<\/li>\r\n\t<li>Subtract only a single letter from a single numeral. Write VIII for 8, not IIX; 19 is XIX, not IXX.<\/li>\r\n\t<li>Don&rsquo;t subtract a letter from another letter more than ten times greater. This means that you can only subtract I from V or X, and X from L or C, so MIM is illegal.<\/li>\r\n<\/ul>\r\n","input":"<p>Each input line consists of either:<\/p>\r\n\r\n<ul>\r\n\t<li>A Roman numeral between I and MMMMCMXCIX, or<\/li>\r\n\t<li>An arithmetic operation +, &minus;, \/, or *, or the print operator, =<\/li>\r\n<\/ul>\r\n\r\n<p>The input ends at the end-of-\ufb01le.<\/p>\r\n","output":"<p>A line will be output:<\/p>\r\n\r\n<ul>\r\n\t<li>For every print operation, print the value at the top of the stack, or<\/li>\r\n\t<li>One of the error messages, on a line by itself:\r\n\t<ul>\r\n\t\t<li>division by zero exception<\/li>\r\n\t\t<li>stack underflow<\/li>\r\n\t\t<li>out of range exception<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>No other output should be produced<\/p>\r\n","hint":"","original":"1","problem_lang_code":"\uc601\uc5b4"}]