시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 128 MB46312567.568%

문제

EDSAC (ElectronicDelay Storage Automatic Calculator)은 프로그램을 주기억장치에 두고 실행할 수 있는 최초의 디지털 컴퓨터이다. EDSAC에는 가산기를 사용하는 명령어가 내장되어 있으며, 17비트 word 타입과 35비트 double word 타입을 기반으로 계산한다. 또한 입출력을 위해 5비트 텔레타이프 코드를 사용한다.

EDSAC 프로그램은 매우 간단한 어셈블리어로 만들 수 있다. 이 어셈블리어의 각 명령어는 문자 하나와 음이 아닌 십진수 주소값, 그리고 F나 D로 이뤄져 있다. F는 full word타입, D는 double word타입을 의미한다. 예를 들어 명령어 "A 128 F"는 가산기에 메모리 상에서 128 주소에 있는 full word 타입 변수값을 더하라는 의미이다. 이 연산은 이진수로 11100000100000000으로 표현된다. 앞의 11100은 "add"를 의미하는 5비트의 opcode이고, 다음 11비트 00010000000(=128)은 피연산자를 나타내며, 마지막의 0은 full word타입을 연산한다는 것을 의미한다. (double word 타입이라면 마지막 자리는 1이 된다.)

EDSAC 연산은 부동소수점 2의 보수 연산이지만, 단순한 정수 사칙연산이 아닌 현대 컴퓨터와 비슷한 방법으로 수를 연산한다. EDSAC의 연산 장치는 소수점이 가장 높은 자릿수(가장 왼쪽에 있는 자릿수)와 그 다음 자릿수(바로 오른쪽에 있는 자릿수) 사이에 있다고 가정한다. 따라서 17비트 word 타입 x의 표현 범위는 -1.0 ≤ x < 1.0이다.

 값 이진수 표현 
-1.0   10000000000000000
 1/2  01000000000000000
 3/4  01100000000000000
 -1/2 11000000000000000

따라서 가능한 가장 큰 양의 실수는 01111111111111111 = 0.9999847412109375이고, 가장 작은 양의 실수는 00000000000000001 = 2^(-16) = 0.0000152587890625이다.

우연의 일치인지 의도적인 설계인지, opcode add 연산과 텔레타이프 코드 'A'는 11100으로 일치하며, subtract 연산과 'S' 역시 01100으로 일치한다. 또한 텔레타이프 코드로 표현할 수 있는 알파벳은 "PQWERTYUIOJ#SZK*?F@D!HNM&LXGABCV"로 모두 32자인데, 5비트 opcode로 표현할 수 있는 수의 개수도 32개이다. (텔레타이프 코드로 P는 00000, Q는 00001로 위 순서대로 증가하여 V는 11111으로 표현된다.) 이 특성 덕분에 EDSAC 어셈블러를 만들기가 쉬워졌다.

그러나 EDSAC 어셈블러에는 특별히 데이터 값을 표현하는 특별한 코드가 없다. 그래서 한 EDSAC 프로그래머는 일반 명령어를 데이터 값 표현에 쓰기로 했다. 예를 들어 상수 3/4(01100000000000000)는 “S 0 F로 표현되며, 1/3(약 00101010101010101)은 “T 682 D”로 표현된다. (T=00101, 682=010101010101)

십진수가 입력으로 주어졌을 때 이를 적절한 EDSAC 명령어로 표현하는 프로그램을 작성하시오.

입력

입력의 첫째 줄에는 테스트 케이스의 수를 나타내는 정수 P(1 ≤ P ≤ 1000)가 하나 주어진다. 각 테스트 케이스는 십진수 D가 한 줄 주어진다. D는 sd.ddd....의 형태로 주어지는데, s는 마이너스 부호이고 생략될 수 있다. d는 십진수 한 자리(0-9)이다. 소수점 이하는 최소 한 자리 이상 최대 16자리 이하로 주어진다.

출력

각 테스트 케이스에 대해 입력으로 주어진 수를 표현하기 위한 EDSAC 명령어 한 줄을 출력한다. 출력은 opcode 문자 하나와 공백 하나, 음이 아닌 십진수 정수인 피연산자 하나와 공백 하나, 'F' 또는 'D'로 이뤄져 있다. 만약 입력으로 주어진 수가 정확히 17비트로 표현할 수 없는 수라면, 0에 더 가까운 수로 표현한다. (양수라면 내림, 음수라면 올림한다.)

D가 -1.0 <= D < 1.0 범위의 수가 아니라면 EDSAC 명령어 대신 "INVALID VALUE"를 출력한다.

예제 입력 1

16
0.5
-0.5
-1.0000000
0.1
0.0000152587890625
0.0000152587890624
0.0000152587890626
-0.0000152587890625
-0.0000152587890624
-0.0000152587890626
0.9999999999999999
-0.9999999999999999
-5.3
9.1
-1.0000000000000001
0.31415926

예제 출력 1

I 0 F
& 0 F
? 0 F
Q 1228 D
P 0 D
P 0 F
P 0 D
V 2047 D
P 0 F
V 2047 D
* 2047 D
? 0 D
INVALID VALUE
INVALID VALUE
INVALID VALUE
T 54 F
[{"problem_id":"2677","problem_lang":"0","title":"\uc5d0\ub4dc\uc0ad \ub9cc\ub4e4\uae30","description":"<p>EDSAC (ElectronicDelay Storage Automatic Calculator)\uc740 \ud504\ub85c\uadf8\ub7a8\uc744 \uc8fc\uae30\uc5b5\uc7a5\uce58\uc5d0 \ub450\uace0 \uc2e4\ud589\ud560 \uc218 \uc788\ub294 \ucd5c\ucd08\uc758 \ub514\uc9c0\ud138 \ucef4\ud4e8\ud130\uc774\ub2e4.&nbsp;EDSAC\uc5d0\ub294 \uac00\uc0b0\uae30\ub97c \uc0ac\uc6a9\ud558\ub294 \uba85\ub839\uc5b4\uac00 \ub0b4\uc7a5\ub418\uc5b4 \uc788\uc73c\uba70,&nbsp;17\ube44\ud2b8 word&nbsp;\ud0c0\uc785\uacfc 35\ube44\ud2b8 double word \ud0c0\uc785\uc744 \uae30\ubc18\uc73c\ub85c \uacc4\uc0b0\ud55c\ub2e4. \ub610\ud55c \uc785\ucd9c\ub825\uc744 \uc704\ud574&nbsp;5\ube44\ud2b8 \ud154\ub808\ud0c0\uc774\ud504 \ucf54\ub4dc\ub97c \uc0ac\uc6a9\ud55c\ub2e4.<\/p>\r\n\r\n<p>EDSAC \ud504\ub85c\uadf8\ub7a8\uc740 \ub9e4\uc6b0 \uac04\ub2e8\ud55c \uc5b4\uc148\ube14\ub9ac\uc5b4\ub85c \ub9cc\ub4e4 \uc218 \uc788\ub2e4. \uc774 \uc5b4\uc148\ube14\ub9ac\uc5b4\uc758 \uac01 \uba85\ub839\uc5b4\ub294 \ubb38\uc790 \ud558\ub098\uc640 \uc74c\uc774 \uc544\ub2cc \uc2ed\uc9c4\uc218 \uc8fc\uc18c\uac12, \uadf8\ub9ac\uace0 F\ub098 D\ub85c \uc774\ub904\uc838 \uc788\ub2e4. F\ub294 full word\ud0c0\uc785, D\ub294 double word\ud0c0\uc785\uc744 \uc758\ubbf8\ud55c\ub2e4. \uc608\ub97c \ub4e4\uc5b4 \uba85\ub839\uc5b4 &quot;A 128 F&quot;\ub294 \uac00\uc0b0\uae30\uc5d0 \uba54\ubaa8\ub9ac \uc0c1\uc5d0\uc11c&nbsp;128 \uc8fc\uc18c\uc5d0 \uc788\ub294 full word \ud0c0\uc785 \ubcc0\uc218\uac12\uc744 \ub354\ud558\ub77c\ub294 \uc758\ubbf8\uc774\ub2e4. \uc774 \uc5f0\uc0b0\uc740 \uc774\uc9c4\uc218\ub85c&nbsp;11100000100000000\uc73c\ub85c \ud45c\ud604\ub41c\ub2e4. \uc55e\uc758&nbsp;11100\uc740 &quot;add&quot;\ub97c \uc758\ubbf8\ud558\ub294 5\ube44\ud2b8\uc758 opcode\uc774\uace0, \ub2e4\uc74c 11\ube44\ud2b8&nbsp;00010000000(=128)\uc740 \ud53c\uc5f0\uc0b0\uc790\ub97c \ub098\ud0c0\ub0b4\uba70, \ub9c8\uc9c0\ub9c9\uc758 0\uc740 full word\ud0c0\uc785\uc744 \uc5f0\uc0b0\ud55c\ub2e4\ub294 \uac83\uc744 \uc758\ubbf8\ud55c\ub2e4. (double word \ud0c0\uc785\uc774\ub77c\uba74 \ub9c8\uc9c0\ub9c9 \uc790\ub9ac\ub294 1\uc774 \ub41c\ub2e4.)<\/p>\r\n\r\n<p>EDSAC \uc5f0\uc0b0\uc740 \ubd80\ub3d9\uc18c\uc218\uc810 2\uc758 \ubcf4\uc218 \uc5f0\uc0b0\uc774\uc9c0\ub9cc, \ub2e8\uc21c\ud55c \uc815\uc218 \uc0ac\uce59\uc5f0\uc0b0\uc774 \uc544\ub2cc \ud604\ub300 \ucef4\ud4e8\ud130\uc640 \ube44\uc2b7\ud55c \ubc29\ubc95\uc73c\ub85c \uc218\ub97c \uc5f0\uc0b0\ud55c\ub2e4.&nbsp;EDSAC\uc758 \uc5f0\uc0b0 \uc7a5\uce58\ub294 \uc18c\uc218\uc810\uc774 \uac00\uc7a5 \ub192\uc740 \uc790\ub9bf\uc218(\uac00\uc7a5 \uc67c\ucabd\uc5d0 \uc788\ub294 \uc790\ub9bf\uc218)\uc640 \uadf8 \ub2e4\uc74c \uc790\ub9bf\uc218(\ubc14\ub85c \uc624\ub978\ucabd\uc5d0 \uc788\ub294 \uc790\ub9bf\uc218) \uc0ac\uc774\uc5d0 \uc788\ub2e4\uace0 \uac00\uc815\ud55c\ub2e4. \ub530\ub77c\uc11c 17\ube44\ud2b8 word \ud0c0\uc785 x\uc758 \ud45c\ud604 \ubc94\uc704\ub294 -1.0&nbsp;&le;&nbsp;x &lt; 1.0\uc774\ub2e4.<\/p>\r\n\r\n<table class=\"table table-bordered\" style=\"width:30%\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>&nbsp;\uac12<\/th>\r\n\t\t\t<th>\uc774\uc9c4\uc218 \ud45c\ud604&nbsp;<\/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>-1.0&nbsp;<\/td>\r\n\t\t\t<td>&nbsp;10000000000000000<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>&nbsp;1\/2<\/td>\r\n\t\t\t<td>&nbsp;01000000000000000<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>&nbsp;3\/4<\/td>\r\n\t\t\t<td>&nbsp;01100000000000000<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>&nbsp;-1\/2<\/td>\r\n\t\t\t<td>11000000000000000<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>\ub530\ub77c\uc11c \uac00\ub2a5\ud55c \uac00\uc7a5 \ud070 \uc591\uc758 \uc2e4\uc218\ub294&nbsp;01111111111111111 = 0.9999847412109375\uc774\uace0, \uac00\uc7a5 \uc791\uc740 \uc591\uc758 \uc2e4\uc218\ub294&nbsp;00000000000000001 = 2^(-16) = 0.0000152587890625\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc6b0\uc5f0\uc758 \uc77c\uce58\uc778\uc9c0 \uc758\ub3c4\uc801\uc778 \uc124\uacc4\uc778\uc9c0, opcode add \uc5f0\uc0b0\uacfc&nbsp;\ud154\ub808\ud0c0\uc774\ud504 \ucf54\ub4dc &#39;A&#39;\ub294 11100\uc73c\ub85c \uc77c\uce58\ud558\uba70, subtract&nbsp;\uc5f0\uc0b0\uacfc &#39;S&#39; \uc5ed\uc2dc 01100\uc73c\ub85c \uc77c\uce58\ud55c\ub2e4. \ub610\ud55c \ud154\ub808\ud0c0\uc774\ud504 \ucf54\ub4dc\ub85c \ud45c\ud604\ud560 \uc218 \uc788\ub294 \uc54c\ud30c\ubcb3\uc740&nbsp;&quot;PQWERTYUIOJ#SZK*?F@D!HNM&amp;LXGABCV&quot;\ub85c \ubaa8\ub450 32\uc790\uc778\ub370, 5\ube44\ud2b8 opcode\ub85c \ud45c\ud604\ud560 \uc218 \uc788\ub294 \uc218\uc758 \uac1c\uc218\ub3c4 32\uac1c\uc774\ub2e4. (\ud154\ub808\ud0c0\uc774\ud504 \ucf54\ub4dc\ub85c P\ub294 00000, Q\ub294 00001\ub85c \uc704 \uc21c\uc11c\ub300\ub85c \uc99d\uac00\ud558\uc5ec V\ub294 11111\uc73c\ub85c \ud45c\ud604\ub41c\ub2e4.) \uc774 \ud2b9\uc131 \ub355\ubd84\uc5d0&nbsp;EDSAC \uc5b4\uc148\ube14\ub7ec\ub97c \ub9cc\ub4e4\uae30\uac00 \uc26c\uc6cc\uc84c\ub2e4.<\/p>\r\n\r\n<p>\uadf8\ub7ec\ub098&nbsp;EDSAC \uc5b4\uc148\ube14\ub7ec\uc5d0\ub294 \ud2b9\ubcc4\ud788 \ub370\uc774\ud130 \uac12\uc744 \ud45c\ud604\ud558\ub294 \ud2b9\ubcc4\ud55c \ucf54\ub4dc\uac00 \uc5c6\ub2e4.&nbsp;\uadf8\ub798\uc11c \ud55c EDSAC \ud504\ub85c\uadf8\ub798\uba38\ub294 \uc77c\ubc18 \uba85\ub839\uc5b4\ub97c \ub370\uc774\ud130 \uac12 \ud45c\ud604\uc5d0 \uc4f0\uae30\ub85c \ud588\ub2e4. \uc608\ub97c \ub4e4\uc5b4 \uc0c1\uc218 3\/4(01100000000000000)\ub294 &ldquo;S 0 F\ub85c \ud45c\ud604\ub418\uba70, 1\/3(\uc57d 00101010101010101)\uc740 &ldquo;T 682 D&rdquo;\ub85c \ud45c\ud604\ub41c\ub2e4. (T=00101, 682=010101010101)<\/p>\r\n\r\n<p>\uc2ed\uc9c4\uc218\uac00 \uc785\ub825\uc73c\ub85c \uc8fc\uc5b4\uc84c\uc744 \ub54c \uc774\ub97c \uc801\uc808\ud55c EDSAC \uba85\ub839\uc5b4\ub85c \ud45c\ud604\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc2dc\uc624.<\/p>\r\n","input":"<p>\uc785\ub825\uc758 \uccab\uc9f8 \uc904\uc5d0\ub294 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc218\ub97c \ub098\ud0c0\ub0b4\ub294&nbsp;\uc815\uc218 P(1&nbsp;&le;&nbsp;P&nbsp;&le; 1000)\uac00 \ud558\ub098 \uc8fc\uc5b4\uc9c4\ub2e4. \uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \uc2ed\uc9c4\uc218 D\uac00 \ud55c \uc904 \uc8fc\uc5b4\uc9c4\ub2e4. D\ub294 sd.ddd....\uc758 \ud615\ud0dc\ub85c \uc8fc\uc5b4\uc9c0\ub294\ub370, s\ub294 \ub9c8\uc774\ub108\uc2a4 \ubd80\ud638\uc774\uace0 \uc0dd\ub7b5\ub420 \uc218 \uc788\ub2e4. d\ub294 \uc2ed\uc9c4\uc218 \ud55c \uc790\ub9ac(0-9)\uc774\ub2e4. \uc18c\uc218\uc810 \uc774\ud558\ub294 \ucd5c\uc18c \ud55c \uc790\ub9ac \uc774\uc0c1 \ucd5c\ub300 16\uc790\ub9ac \uc774\ud558\ub85c \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8&nbsp;\ucf00\uc774\uc2a4\uc5d0 \ub300\ud574 \uc785\ub825\uc73c\ub85c \uc8fc\uc5b4\uc9c4 \uc218\ub97c \ud45c\ud604\ud558\uae30 \uc704\ud55c EDSAC \uba85\ub839\uc5b4 \ud55c \uc904\uc744 \ucd9c\ub825\ud55c\ub2e4. \ucd9c\ub825\uc740 opcode \ubb38\uc790 \ud558\ub098\uc640 \uacf5\ubc31 \ud558\ub098, \uc74c\uc774 \uc544\ub2cc \uc2ed\uc9c4\uc218 \uc815\uc218\uc778 \ud53c\uc5f0\uc0b0\uc790 \ud558\ub098\uc640 \uacf5\ubc31 \ud558\ub098, &#39;F&#39; \ub610\ub294 &#39;D&#39;\ub85c \uc774\ub904\uc838 \uc788\ub2e4. \ub9cc\uc57d \uc785\ub825\uc73c\ub85c \uc8fc\uc5b4\uc9c4 \uc218\uac00 \uc815\ud655\ud788 17\ube44\ud2b8\ub85c \ud45c\ud604\ud560 \uc218 \uc5c6\ub294 \uc218\ub77c\uba74, 0\uc5d0 \ub354 \uac00\uae4c\uc6b4 \uc218\ub85c \ud45c\ud604\ud55c\ub2e4. (\uc591\uc218\ub77c\uba74 \ub0b4\ub9bc, \uc74c\uc218\ub77c\uba74 \uc62c\ub9bc\ud55c\ub2e4.)<\/p>\r\n\r\n<p>D\uac00&nbsp;-1.0 &lt;= D &lt; 1.0 \ubc94\uc704\uc758 \uc218\uac00 \uc544\ub2c8\ub77c\uba74 EDSAC \uba85\ub839\uc5b4 \ub300\uc2e0&nbsp;&quot;INVALID VALUE&quot;\ub97c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean"},{"problem_id":"2677","problem_lang":"1","title":"Programming the EDSAC","description":"<p>The world&#39;s first full-scale, stored-program, electronic, digital computer was the EDSAC (ElectronicDelay Storage Automatic Calculator). The EDSAC had an accumulator-based instruction set,operating on 17-bit words (and 35-bit double words), and used a 5-bit teletypewriter code for inputand output.<\/p>\r\n\r\n<p>The EDSAC was programmed using a very simple assembly language: a single letter opcodefollowed by an unsigned decimal address, followed by the the letter &#39;F&#39; (for full word) or &#39;D&#39; (for double word). For example, the instruction &quot;A 128 F&quot; would mean &quot;add the full word at location 128 to the accumulator&quot;, and would be assembled into the 17-bit binary value, 11100000100000000,consisting of a 5-bit opcode (11100 = &quot;add&quot;), an 11-bit operand (00010000000 = 128), and a single 0 bit denoting a full word operation (a 1 bit would indicate a double word operation).<\/p>\r\n\r\n<p>Although arithmetic on the EDSAC was fixed point two&#39;s complement binary, it was not mere integer arithmetic (as is common with modern machines). The EDSAC hardware assumed a binary point between the leftmost bit and its immediate successor. Thus the hardware could handle only values in the range -1.0 &lt;= x &lt; 1.0. For example:<\/p>\r\n\r\n<table class=\"table table-bordered\" style=\"width:40%\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>Value<\/th>\r\n\t\t\t<th>Binary Representation<\/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>-1.0<\/td>\r\n\t\t\t<td>10000000000000000<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>1\/2<\/td>\r\n\t\t\t<td>01000000000000000<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>3\/4<\/td>\r\n\t\t\t<td>01100000000000000<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>-1\/2<\/td>\r\n\t\t\t<td>11000000000000000<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n\r\n<p>As you can see, the largest possible positive value was:<\/p>\r\n\r\n<p>01111111111111111 = 0.9999847412109375<\/p>\r\n\r\n<p>and the smallest possible positive value was:<\/p>\r\n\r\n<p>00000000000000001 = 2<sup>-16<\/sup> = 0.0000152587890625<\/p>\r\n\r\n<p>(This also happens to be the increment between successive values on the EDSAC).<\/p>\r\n\r\n<p>By a curious coincidence (or an elegant design decision), the opcode for the add operation (11100) was the same as the teleprinter code for the letter &#39;A&#39;. The opcode for subtract was the same as the teleprinter code for &#39;S&#39; (01100), and so on. This simplified the programming for the assembler (which, incidentally, was a mere 31 instructions long). The EDSAC teleprinter alphabet was &quot;PQWERTYUIOJ#SZK*?F@D!HNM&amp;LXGABCV&quot; (with &#39;P&#39; = 00000, &#39;Q&#39; = 00001, and so on, up to &#39;V&#39;= 11111).<\/p>\r\n\r\n<p>Unfortunately, the EDSAC assembler had no special directives for data values. On the other hand, there was no reason that ordinary instructions couldn&#39;t be used for this, thus, an EDSAC programmer desiring to reserve space for the constant 3\/4 (represented as 01100000000000000) would use theinstruction &quot;S 0 F&quot; and for 1\/3 (which is approximately represented as 00101010101010101) &quot;T 682 D&quot;, and so on.<\/p>\r\n\r\n<p>Your job is to write a program that will translate decimal input values into the appropriate EDSAC instructions.<\/p>\r\n","input":"<p>The first line of input contains a single integer P, (1 &le; P &le; 1000), which is the number of data sets that follow. Each data set is a single line that consists of two space separated values N and D. N is the data set number. D is the decimal number of the form sd.ddd&hellip;., where s is an optional minus sign, and d is any decimal digit (0-9). There will be at least 1 and at most 16 digits after the decimal point.<\/p>\r\n","output":"<p>For each data set there is one line of output. It contains the EDSAC instruction necessary to specify the given constant. The instruction should be printed as follows: the &quot;opcode&quot; character followed by a space followed by the operand (as a non-negative decimal integer) followed by a space followed by an &#39;F&#39; or &#39;D&#39; (as appropriate). If the constant cannot be represented exactly in 17 bits, the value is to be rounded toward zero (up for negative, down for positive numbers). If the input value D is not in the range -1.0 &lt;= D &lt; 1.0, the string &quot;INVALID VALUE&quot; should be printed instead of an EDSAC instruction.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English"}]