Logo
(追記) (追記ここまで)

31221번 - 어려운 정수 맞히기 게임 다국어인터랙티브

시간 제한메모리 제한제출정답맞힌 사람정답 비율
3 초 1024 MB4191067725.413%

문제

이 문제는 인터랙티브 문제입니다.

흐즈로는 음이 아닌 정수 $x$ (0ドル \le x \le 10^{18}$)를 하나 가지고 정수 맞히기 게임을 하고자 합니다. 여러분은 질문을 하여 숨겨진 정수 $x$를 맞혀야 합니다. 하지만, 흐즈로는 지금까지 이러한 종류의 문제만 몇백 개 정도 있었다는 사실을 알고 있습니다. 그렇기에 흐즈로는 여러분이 문제를 쉽게는 풀 수 없도록 그 누구도 생각하지 못했을 종류의 질문을 생각해 냈습니다. 여러분이 사용할 수 있는 질문은 다음과 같습니다.

여러분은 두 음이 아닌 정수 $a$와 $b$를 정해서, 흐즈로에게 질문을 할 수 있습니다. 질문으로 주어진 두 정수 $a$와 $b$에 따라, 흐즈로는 다음 값을 계산합니다.

$$\sqrt{(x-a)}-b$$

흐즈로는 계산 결과에 따라 이 값이 양수인지, 음수인지, 아니면 0ドル$인지 여러분에게 알려줍니다. 75ドル$개 이하의 질문을 사용하여 정수를 맞힐 수 있다면 여러분이 승리하고, 질문의 개수가 75ドル$개를 초과할 경우 여러분이 패배합니다. 그러나, $x-a$가 음수가 되는 질문을 한다면 게임이 즉시 종료되고 여러분이 패배합니다. 여러분은 과연 정수의 값을 맞히고 흐즈로를 이길 수 있을까요?

입력

첫 번째 줄에 테스트 케이스의 개수 $n$이 주어집니다. (1ドル \le n \le 100$)

출력

제한

인터랙션

여러분은 다음을 표준 출력 (stdout)으로 출력하여 질문을 할 수 있습니다.

  • ? a b: $\sqrt{(x-a)}-b$의 값에 대해 질문합니다. (0ドル \le a,b \le 10^{18}$)

인터랙터는 계산한 값에 따라 문자를 한 줄에 표준 입력 (stdin)으로 반환하는데, 값이 양수일 경우 +를, 음수일 경우 -를, 0ドル$일 경우 0을 반환합니다. 단, 질문의 개수가 75ドル$개를 초과하였거나 $x-a$의 값이 음수였을 경우 인터랙터는 결과로 !를 반환합니다. 그 즉시 프로그램을 정상 종료해야 하며, 이 경우 채점 결과로 틀렸습니다를 받습니다. 프로그램이 정상 종료되지 않으면 그 외의 채점 결과를 받을 수 있음에 유의하세요.

만약 $x$의 값을 알아낸 경우, 표준 출력 스트림으로 다음을 한 줄에 출력해야 합니다.

  • ! v: $x$의 값은 $v$입니다. (0ドル \le v \le 10^{18}$)

그 후 해결해야 할 테스트 케이스가 남아 있다면 다음 테스트 케이스로 넘어가고, 그렇지 않다면 즉시 프로그램을 종료해야 합니다. ! v를 출력하는 것은 질문의 개수에 포함되지 않습니다.

모든 테스트 케이스에 대해서 $x$의 값을 알아내는 데 성공하였다면 채점 결과로 맞았습니다를 받습니다. 그렇지 않다면 틀렸습니다를 받습니다.

각 줄을 출력한 후에는 표준 출력 버퍼를 flush해 주어야 합니다. 언어별로 표준 출력 버퍼를 flush하는 방법은 다음과 같습니다.

  • C: fflush(stdout)
  • C++: cout.flush()
  • Java/Kotlin: System.out.flush()
  • Python: sys.stdout.flush()
  • 이외의 언어: 각 언어의 레퍼런스를 참고합니다.

본 문제의 인터랙터는 적응적이지 않습니다. 다시 말해, 모든 테스트 케이스에서 $x$의 값은 인터랙션 이전부터 고정되어 있으며 인터랙션 도중에 변하지 않습니다.

예제 입력 1

2
+
-
0
+
0

예제 출력 1

? 0 0
? 1 1
? 1 0
! 1
? 0 0
? 1 1
! 2

예제의 줄과 줄 사이의 공백은 인터랙션의 순서를 표현하기 위해 임의로 추가되었으며, 실제 입출력에는 줄과 줄 사이에 공백이 없음에 유의해야 합니다.

예제의 첫 번째 테스트 케이스에서 숨겨진 정수는 1ドル$입니다. 예제 출력의 질문과 그에 대응되는 답은 다음과 같습니다.

  • $a=0,ドル $b=0$에 대해 질문했을 때, $\sqrt{x-a}-b=\sqrt{1}-0=1$입니다. 결과가 양수이므로 인터랙터는 +를 반환합니다.
  • $a=1,ドル $b=1$에 대해 질문했을 때, $\sqrt{x-a}-b=\sqrt{0}-1=-1$입니다. 결과가 음수이므로 인터랙터는 -를 반환합니다.
  • $a=1,ドル $b=0$에 대해 질문했을 때, $\sqrt{x-a}-b=\sqrt{0}-0=0$입니다. 결과가 0ドル$이므로 인터랙터는 0을 반환합니다.

이 시점에서 $x=1$임을 알 수 있으므로, ! 1을 출력해 $x$의 값을 확정합니다.

예제의 두 번째 테스트 케이스에서 숨겨진 정수는 2ドル$입니다. 예제 출력의 질문과 그에 대응되는 답은 다음과 같습니다.

  • $a=0,ドル $b=0$에 대해 질문했을 때, $\sqrt{x-a}-b=\sqrt{2}-0=\sqrt{2}$입니다. 결과가 양수이므로 인터랙터는 +를 반환합니다.
  • $a=1,ドル $b=1$에 대해 질문했을 때, $\sqrt{x-a}-b=\sqrt{1}-1=0$입니다. 결과가 0ドル$이므로 인터랙터는 0을 반환합니다.

이 시점에서 $x=2$임을 알 수 있으므로, ! 2를 출력해 $x$의 값을 확정합니다.

노트

본 문제는 입출력의 양이 많은 관계로 최악의 경우 입출력에 약 500ms 가량의 시간이 소요될 수 있습니다. 이 점에 유의하여 문제를 해결해 주시기 바랍니다.

[{"problem_id":"31221","problem_lang":"0","title":"\uc5b4\ub824\uc6b4 \uc815\uc218 \ub9de\ud788\uae30 \uac8c\uc784","description":"<p><strong>\uc774 \ubb38\uc81c\ub294 \uc778\ud130\ub799\ud2f0\ube0c \ubb38\uc81c\uc785\ub2c8\ub2e4.<\/strong><\/p>\r\n\r\n<p>\ud750\uc988\ub85c\ub294 \uc74c\uc774 \uc544\ub2cc \uc815\uc218 $x$ ($0 \\le x \\le 10^{18}$)\ub97c \ud558\ub098 \uac00\uc9c0\uace0 \uc815\uc218 \ub9de\ud788\uae30 \uac8c\uc784\uc744 \ud558\uace0\uc790 \ud569\ub2c8\ub2e4. \uc5ec\ub7ec\ubd84\uc740 \uc9c8\ubb38\uc744 \ud558\uc5ec \uc228\uaca8\uc9c4 \uc815\uc218 $x$\ub97c \ub9de\ud600\uc57c \ud569\ub2c8\ub2e4. \ud558\uc9c0\ub9cc, \ud750\uc988\ub85c\ub294 \uc9c0\uae08\uae4c\uc9c0 \uc774\ub7ec\ud55c \uc885\ub958\uc758 \ubb38\uc81c\ub9cc \uba87\ubc31 \uac1c \uc815\ub3c4 \uc788\uc5c8\ub2e4\ub294 \uc0ac\uc2e4\uc744 \uc54c\uace0 \uc788\uc2b5\ub2c8\ub2e4. \uadf8\ub807\uae30\uc5d0 \ud750\uc988\ub85c\ub294 \uc5ec\ub7ec\ubd84\uc774 \ubb38\uc81c\ub97c \uc27d\uac8c\ub294 \ud480 \uc218 \uc5c6\ub3c4\ub85d \uadf8 \ub204\uad6c\ub3c4 \uc0dd\uac01\ud558\uc9c0 \ubabb\ud588\uc744 \uc885\ub958\uc758 \uc9c8\ubb38\uc744 \uc0dd\uac01\ud574 \ub0c8\uc2b5\ub2c8\ub2e4. \uc5ec\ub7ec\ubd84\uc774 \uc0ac\uc6a9\ud560 \uc218 \uc788\ub294 \uc9c8\ubb38\uc740 \ub2e4\uc74c\uacfc \uac19\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uc5ec\ub7ec\ubd84\uc740 \ub450 \uc74c\uc774 \uc544\ub2cc \uc815\uc218 $a$\uc640 $b$\ub97c \uc815\ud574\uc11c, \ud750\uc988\ub85c\uc5d0\uac8c \uc9c8\ubb38\uc744 \ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc9c8\ubb38\uc73c\ub85c \uc8fc\uc5b4\uc9c4 \ub450 \uc815\uc218 $a$\uc640 $b$\uc5d0 \ub530\ub77c, \ud750\uc988\ub85c\ub294 \ub2e4\uc74c \uac12\uc744 \uacc4\uc0b0\ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<p>$$\\sqrt{(x-a)}-b$$<\/p>\r\n\r\n<p>\ud750\uc988\ub85c\ub294 \uacc4\uc0b0 \uacb0\uacfc\uc5d0 \ub530\ub77c \uc774 \uac12\uc774 \uc591\uc218\uc778\uc9c0, \uc74c\uc218\uc778\uc9c0, \uc544\ub2c8\uba74 $0$\uc778\uc9c0 \uc5ec\ub7ec\ubd84\uc5d0\uac8c \uc54c\ub824\uc90d\ub2c8\ub2e4. $75$\uac1c \uc774\ud558\uc758 \uc9c8\ubb38\uc744 \uc0ac\uc6a9\ud558\uc5ec \uc815\uc218\ub97c \ub9de\ud790 \uc218 \uc788\ub2e4\uba74 \uc5ec\ub7ec\ubd84\uc774 \uc2b9\ub9ac\ud558\uace0, \uc9c8\ubb38\uc758 \uac1c\uc218\uac00 $75$\uac1c\ub97c \ucd08\uacfc\ud560 \uacbd\uc6b0 \uc5ec\ub7ec\ubd84\uc774 \ud328\ubc30\ud569\ub2c8\ub2e4. \uadf8\ub7ec\ub098, <strong>$x-a$\uac00 \uc74c\uc218\uac00 \ub418\ub294 \uc9c8\ubb38\uc744 \ud55c\ub2e4\uba74 \uac8c\uc784\uc774 \uc989\uc2dc \uc885\ub8cc\ub418\uace0 \uc5ec\ub7ec\ubd84\uc774 \ud328\ubc30\ud569\ub2c8\ub2e4.<\/strong> \uc5ec\ub7ec\ubd84\uc740 \uacfc\uc5f0 \uc815\uc218\uc758 \uac12\uc744 \ub9de\ud788\uace0 \ud750\uc988\ub85c\ub97c \uc774\uae38 \uc218 \uc788\uc744\uae4c\uc694?<\/p>\r\n","input":"<p>\uccab \ubc88\uc9f8 \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uac1c\uc218 $n$\uc774 \uc8fc\uc5b4\uc9d1\ub2c8\ub2e4. ($1 \\le n \\le 100$)<\/p>\r\n","output":"","hint":"<p>\ubcf8 \ubb38\uc81c\ub294 \uc785\ucd9c\ub825\uc758 \uc591\uc774 \ub9ce\uc740 \uad00\uacc4\ub85c \ucd5c\uc545\uc758 \uacbd\uc6b0 \uc785\ucd9c\ub825\uc5d0 \uc57d 500ms \uac00\ub7c9\uc758 \uc2dc\uac04\uc774 \uc18c\uc694\ub420 \uc218 \uc788\uc2b5\ub2c8\ub2e4. \uc774 \uc810\uc5d0 \uc720\uc758\ud558\uc5ec \ubb38\uc81c\ub97c \ud574\uacb0\ud574 \uc8fc\uc2dc\uae30 \ubc14\ub78d\ub2c8\ub2e4.<\/p>\r\n","original":"1","html_title":"0","problem_lang_tcode":"Korean","custom_inter":"<p>\uc5ec\ub7ec\ubd84\uc740 \ub2e4\uc74c\uc744 \ud45c\uc900 \ucd9c\ub825 (stdout)\uc73c\ub85c \ucd9c\ub825\ud558\uc5ec \uc9c8\ubb38\uc744 \ud560 \uc218 \uc788\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li><strong><span style=\"color:#e74c3c;\"><code>? a b<\/code><\/span><\/strong>: $\\sqrt{(x-a)}-b$\uc758 \uac12\uc5d0 \ub300\ud574 \uc9c8\ubb38\ud569\ub2c8\ub2e4. ($0 \\le a,b \\le 10^{18}$)<\/li>\r\n<\/ul>\r\n\r\n<p>\uc778\ud130\ub799\ud130\ub294 \uacc4\uc0b0\ud55c \uac12\uc5d0 \ub530\ub77c \ubb38\uc790\ub97c \ud55c \uc904\uc5d0 \ud45c\uc900 \uc785\ub825 (stdin)\uc73c\ub85c \ubc18\ud658\ud558\ub294\ub370, \uac12\uc774 \uc591\uc218\uc77c \uacbd\uc6b0 <strong><span style=\"color:#e74c3c;\"><code>+<\/code><\/span><\/strong>\ub97c, \uc74c\uc218\uc77c \uacbd\uc6b0 <strong><span style=\"color:#e74c3c;\"><code>-<\/code><\/span><\/strong>\ub97c, $0$\uc77c \uacbd\uc6b0 <strong><code><span style=\"color:#e74c3c;\">0<\/span><\/code><\/strong>\uc744 \ubc18\ud658\ud569\ub2c8\ub2e4. \ub2e8, \uc9c8\ubb38\uc758 \uac1c\uc218\uac00 $75$\uac1c\ub97c \ucd08\uacfc\ud558\uc600\uac70\ub098 $x-a$\uc758 \uac12\uc774 \uc74c\uc218\uc600\uc744 \uacbd\uc6b0 \uc778\ud130\ub799\ud130\ub294 \uacb0\uacfc\ub85c <strong><span style=\"color:#e74c3c;\"><code>!<\/code><\/span><\/strong>\ub97c \ubc18\ud658\ud569\ub2c8\ub2e4. \uadf8 \uc989\uc2dc \ud504\ub85c\uadf8\ub7a8\uc744 \uc815\uc0c1 \uc885\ub8cc\ud574\uc57c \ud558\uba70, \uc774 \uacbd\uc6b0 \ucc44\uc810 \uacb0\uacfc\ub85c <strong>\ud2c0\ub838\uc2b5\ub2c8\ub2e4<\/strong>\ub97c \ubc1b\uc2b5\ub2c8\ub2e4. \ud504\ub85c\uadf8\ub7a8\uc774 \uc815\uc0c1 \uc885\ub8cc\ub418\uc9c0 \uc54a\uc73c\uba74 \uadf8 \uc678\uc758 \ucc44\uc810 \uacb0\uacfc\ub97c \ubc1b\uc744 \uc218 \uc788\uc74c\uc5d0 \uc720\uc758\ud558\uc138\uc694.<\/p>\r\n\r\n<p>\ub9cc\uc57d $x$\uc758 \uac12\uc744 \uc54c\uc544\ub0b8 \uacbd\uc6b0, \ud45c\uc900 \ucd9c\ub825 \uc2a4\ud2b8\ub9bc\uc73c\ub85c \ub2e4\uc74c\uc744 \ud55c \uc904\uc5d0 \ucd9c\ub825\ud574\uc57c \ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li><strong><span style=\"color:#e74c3c;\"><code>! v<\/code><\/span><\/strong>: $x$\uc758 \uac12\uc740 $v$\uc785\ub2c8\ub2e4. ($0 \\le v \\le 10^{18}$)<\/li>\r\n<\/ul>\r\n\r\n<p>\uadf8 \ud6c4 \ud574\uacb0\ud574\uc57c \ud560 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uac00 \ub0a8\uc544 \uc788\ub2e4\uba74 \ub2e4\uc74c \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub85c \ub118\uc5b4\uac00\uace0, \uadf8\ub807\uc9c0 \uc54a\ub2e4\uba74 \uc989\uc2dc \ud504\ub85c\uadf8\ub7a8\uc744 \uc885\ub8cc\ud574\uc57c \ud569\ub2c8\ub2e4. <strong><span style=\"color:#e74c3c;\"><code>! v<\/code><\/span><\/strong>\ub97c \ucd9c\ub825\ud558\ub294 \uac83\uc740 \uc9c8\ubb38\uc758 \uac1c\uc218\uc5d0 \ud3ec\ud568\ub418\uc9c0 \uc54a\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\ubaa8\ub4e0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0 \ub300\ud574\uc11c $x$\uc758 \uac12\uc744 \uc54c\uc544\ub0b4\ub294 \ub370 \uc131\uacf5\ud558\uc600\ub2e4\uba74 \ucc44\uc810 \uacb0\uacfc\ub85c <strong>\ub9de\uc558\uc2b5\ub2c8\ub2e4<\/strong>\ub97c \ubc1b\uc2b5\ub2c8\ub2e4. \uadf8\ub807\uc9c0 \uc54a\ub2e4\uba74 <strong>\ud2c0\ub838\uc2b5\ub2c8\ub2e4<\/strong>\ub97c \ubc1b\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uac01 \uc904\uc744 \ucd9c\ub825\ud55c \ud6c4\uc5d0\ub294 \ud45c\uc900 \ucd9c\ub825 \ubc84\ud37c\ub97c flush\ud574 \uc8fc\uc5b4\uc57c \ud569\ub2c8\ub2e4. \uc5b8\uc5b4\ubcc4\ub85c \ud45c\uc900 \ucd9c\ub825 \ubc84\ud37c\ub97c flush\ud558\ub294 \ubc29\ubc95\uc740 \ub2e4\uc74c\uacfc \uac19\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>C: <code>fflush(stdout)<\/code><\/li>\r\n\t<li>C++: <code>cout.flush()<\/code><\/li>\r\n\t<li>Java\/Kotlin: <code>System.out.flush()<\/code><\/li>\r\n\t<li>Python: <code>sys.stdout.flush()<\/code><\/li>\r\n\t<li>\uc774\uc678\uc758 \uc5b8\uc5b4: \uac01 \uc5b8\uc5b4\uc758 \ub808\ud37c\ub7f0\uc2a4\ub97c \ucc38\uace0\ud569\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ubcf8 \ubb38\uc81c\uc758 \uc778\ud130\ub799\ud130\ub294 <strong>\uc801\uc751\uc801\uc774\uc9c0 \uc54a\uc2b5\ub2c8\ub2e4<\/strong>. \ub2e4\uc2dc \ub9d0\ud574, \ubaa8\ub4e0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0\uc11c $x$\uc758 \uac12\uc740 \uc778\ud130\ub799\uc158 \uc774\uc804\ubd80\ud130 \uace0\uc815\ub418\uc5b4 \uc788\uc73c\uba70 \uc778\ud130\ub799\uc158 \ub3c4\uc911\uc5d0 \ubcc0\ud558\uc9c0 \uc54a\uc2b5\ub2c8\ub2e4.<\/p>\r\n","sample_explain_1":"<p>\uc608\uc81c\uc758 \uc904\uacfc \uc904 \uc0ac\uc774\uc758 \uacf5\ubc31\uc740 \uc778\ud130\ub799\uc158\uc758 \uc21c\uc11c\ub97c \ud45c\ud604\ud558\uae30 \uc704\ud574 \uc784\uc758\ub85c \ucd94\uac00\ub418\uc5c8\uc73c\uba70, \uc2e4\uc81c \uc785\ucd9c\ub825\uc5d0\ub294 \uc904\uacfc \uc904 \uc0ac\uc774\uc5d0 \uacf5\ubc31\uc774 \uc5c6\uc74c\uc5d0 \uc720\uc758\ud574\uc57c \ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c\uc758 \uccab \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0\uc11c \uc228\uaca8\uc9c4 \uc815\uc218\ub294 $1$\uc785\ub2c8\ub2e4. \uc608\uc81c \ucd9c\ub825\uc758 \uc9c8\ubb38\uacfc \uadf8\uc5d0 \ub300\uc751\ub418\ub294 \ub2f5\uc740 \ub2e4\uc74c\uacfc \uac19\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>$a=0$, $b=0$\uc5d0 \ub300\ud574 \uc9c8\ubb38\ud588\uc744 \ub54c, $\\sqrt{x-a}-b=\\sqrt{1}-0=1$\uc785\ub2c8\ub2e4. \uacb0\uacfc\uac00 \uc591\uc218\uc774\ubbc0\ub85c \uc778\ud130\ub799\ud130\ub294 <span style=\"color:#e74c3c;\"><code><strong>+<\/strong><\/code><\/span>\ub97c \ubc18\ud658\ud569\ub2c8\ub2e4.<\/li>\r\n\t<li>$a=1$, $b=1$\uc5d0 \ub300\ud574 \uc9c8\ubb38\ud588\uc744 \ub54c, $\\sqrt{x-a}-b=\\sqrt{0}-1=-1$\uc785\ub2c8\ub2e4. \uacb0\uacfc\uac00 \uc74c\uc218\uc774\ubbc0\ub85c \uc778\ud130\ub799\ud130\ub294 <span style=\"color:#e74c3c;\"><strong><code>-<\/code><\/strong><\/span>\ub97c \ubc18\ud658\ud569\ub2c8\ub2e4.<\/li>\r\n\t<li>$a=1$, $b=0$\uc5d0 \ub300\ud574 \uc9c8\ubb38\ud588\uc744 \ub54c, $\\sqrt{x-a}-b=\\sqrt{0}-0=0$\uc785\ub2c8\ub2e4. \uacb0\uacfc\uac00 $0$\uc774\ubbc0\ub85c \uc778\ud130\ub799\ud130\ub294 <span style=\"color:#e74c3c;\"><code><strong>0<\/strong><\/code><\/span>\uc744 \ubc18\ud658\ud569\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc774 \uc2dc\uc810\uc5d0\uc11c $x=1$\uc784\uc744 \uc54c \uc218 \uc788\uc73c\ubbc0\ub85c, <span style=\"color:#e74c3c;\"><code><strong>! 1<\/strong><\/code><\/span>\uc744 \ucd9c\ub825\ud574 $x$\uc758 \uac12\uc744 \ud655\uc815\ud569\ub2c8\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c\uc758 \ub450 \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0\uc11c \uc228\uaca8\uc9c4 \uc815\uc218\ub294 $2$\uc785\ub2c8\ub2e4. \uc608\uc81c \ucd9c\ub825\uc758 \uc9c8\ubb38\uacfc \uadf8\uc5d0 \ub300\uc751\ub418\ub294 \ub2f5\uc740 \ub2e4\uc74c\uacfc \uac19\uc2b5\ub2c8\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>$a=0$, $b=0$\uc5d0 \ub300\ud574 \uc9c8\ubb38\ud588\uc744 \ub54c, $\\sqrt{x-a}-b=\\sqrt{2}-0=\\sqrt{2}$\uc785\ub2c8\ub2e4. \uacb0\uacfc\uac00 \uc591\uc218\uc774\ubbc0\ub85c \uc778\ud130\ub799\ud130\ub294 <span style=\"color:#e74c3c;\"><code><strong>+<\/strong><\/code><\/span>\ub97c \ubc18\ud658\ud569\ub2c8\ub2e4.<\/li>\r\n\t<li>$a=1$, $b=1$\uc5d0 \ub300\ud574 \uc9c8\ubb38\ud588\uc744 \ub54c, $\\sqrt{x-a}-b=\\sqrt{1}-1=0$\uc785\ub2c8\ub2e4. \uacb0\uacfc\uac00 $0$\uc774\ubbc0\ub85c \uc778\ud130\ub799\ud130\ub294 <span style=\"color:#e74c3c;\"><strong><code>0<\/code><\/strong><\/span>\uc744 \ubc18\ud658\ud569\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc774 \uc2dc\uc810\uc5d0\uc11c $x=2$\uc784\uc744 \uc54c \uc218 \uc788\uc73c\ubbc0\ub85c, <span style=\"color:#e74c3c;\"><code><strong>! 2<\/strong><\/code><\/span>\ub97c \ucd9c\ub825\ud574 $x$\uc758 \uac12\uc744 \ud655\uc815\ud569\ub2c8\ub2e4.<\/p>\r\n"},{"problem_id":"31221","problem_lang":"1","title":"Hard Number Guessing Game","description":"<p><strong>This is an interactive task.<\/strong><\/p>\r\n\r\n<p>Chromate has a non-negative integer $x$ ($0 \\le x \\le 10^{18}$),&nbsp;with which he will play a number guessing game. You should guess the number $x$ using some questions. However, Chromate knows that there has been a few hundred tasks of the same kind so far. That is why Chromate came up with a completely new kind of question, so that you can&#39;t solve the task so easily. The type of question you can use is as follows.<\/p>\r\n\r\n<p>You can ask Chromate about two non-negative integers $a$ and $b$. Based on the two integers $a$ and $b$, Chromate will compute the result of the following formula.<\/p>\r\n\r\n<p>$$\\sqrt{(x-a)}-b$$<\/p>\r\n\r\n<p>Based on the result, Chromate will tell you if the value is positive, is negative, or is $0$. If you can guess the number using at most $75$ questions, you win. If the number of questions exceed $75$, you lose. However, <strong>if the value of $x-a$ turns out to be negative, the game ends immediately and you lose.<\/strong> Can you successfully guess the integer, and win the game against Chromate?<\/p>\r\n","input":"<p>On the first line of the input, a single integer $n$ is given, representing the number of test cases. ($1 \\le n \\le 100$)<\/p>\r\n\r\n","output":"","hint":"<p>Due to the large amount&nbsp;of interaction&nbsp;in this task, it may take about&nbsp;500 milliseconds for input\/output. Please bear this in mind while solving this task.<\/p>\r\n","original":"0","html_title":"0","problem_lang_tcode":"English","custom_inter":"<p>You can ask a question by printing the following on one line to standard output (stdout).<\/p>\r\n\r\n<ul>\r\n\t<li><span style=\"color:#e74c3c;\"><code><strong>? a b<\/strong><\/code><\/span>: Ask about the value of $\\sqrt{(x-a)}-b$. ($0 \\le a,b \\le 10^{18}$)<\/li>\r\n<\/ul>\r\n\r\n<p>Based on the result of the formula, the interactor returns a single line containing a character to standard input (stdin). Precisely, it returns <span style=\"color:#e74c3c;\"><code><strong>+<\/strong><\/code><\/span> if the value is positive, <strong><span style=\"color:#e74c3c;\"><code>-<\/code><\/span><\/strong> if it is negative, and <strong><code><span style=\"color:#e74c3c;\">0<\/span><\/code><\/strong> if it is $0$. However, if the number of questions has exceeded $75$, or the value of $x-a$ turned out to be negative, the interactor returns the character <strong><span style=\"color:#e74c3c;\"><code>!<\/code><\/span><\/strong>. If this happens, your program must terminate immediately to get the <strong>Wrong Answer<\/strong> verdict. Otherwise, you can get an arbitrary verdict because your solution will continue to read from a closed stream.<\/p>\r\n\r\n<p>If you found out the value of $x$, you must print the following on one line to standard output.<\/p>\r\n\r\n<ul>\r\n\t<li><span style=\"color:#e74c3c;\"><code><strong>! v<\/strong><\/code><\/span>: The value of $x$ is $v$. ($0 \\le v \\le 10^{18}$)<\/li>\r\n<\/ul>\r\n\r\n<p>Afterwards, if there are test cases left to solve, move on to the next test case. Otherwise, terminate the program immediately. Printing <span style=\"color:#e74c3c;\"><code><strong>! v<\/strong><\/code><\/span> does not count toward the number of questions.<\/p>\r\n\r\n<p>If you successfully guessed the value of $x$ for all test cases, you get the <strong>Accepted<\/strong> verdict. Otherwise, you get the <strong>Wrong Answer<\/strong> verdict.<\/p>\r\n\r\n<p>After printing each line do not forget to output the end of line and flush the output. To flush the output, you should use the following.<\/p>\r\n\r\n<ul>\r\n\t<li>C: <code>fflush(stdout)<\/code><\/li>\r\n\t<li>C++: <code>cout.flush()<\/code><\/li>\r\n\t<li>Java\/Kotlin: <code>System.out.flush()<\/code><\/li>\r\n\t<li>Python: <code>sys.stdout.flush()<\/code><\/li>\r\n\t<li>Other languages: read the documentation for your language.<\/li>\r\n<\/ul>\r\n\r\n<p>The interactor for this task is <strong>not adaptive<\/strong>. In other words, the value of $x$ is fixed before interaction, and does not change during the interaction.<\/p>\r\n","sample_explain_1":"<p>The empty space between lines in the example are arbitrarily added to represent the order of interaction. Note that there are no empty lines in the actual interaction.<\/p>\r\n\r\n<p>For the first test case, the hidden integer is $1$. The questions and the corresponding answers are as follows.<\/p>\r\n\r\n<ul>\r\n\t<li>When asked about $a=0$, $b=0$, the result is $\\sqrt{x-a}-b=\\sqrt{1}-0=1$. As this is positive, the interactor returns <span style=\"color:#e74c3c;\"><code><strong>+<\/strong><\/code><\/span>.<\/li>\r\n\t<li>When asked about $a=1$, $b=1$, the result is $\\sqrt{x-a}-b=\\sqrt{0}-1=-1$. As this is negative, the interactor returns <span style=\"color:#e74c3c;\"><code><strong>-<\/strong><\/code><\/span>.<\/li>\r\n\t<li>When asked about $a=1$, $b=0$, the result is $\\sqrt{x-a}-b=\\sqrt{0}-0=0$. As this is exactly $0$, the interactor returns <span style=\"color:#e74c3c;\"><code><strong>0<\/strong><\/code><\/span>.<\/li>\r\n<\/ul>\r\n\r\n<p>As you can infer that $x=1$ at this point, you may output <span style=\"color:#e74c3c;\"><code><strong>! 1<\/strong><\/code><\/span> to secure the value of $x$.<\/p>\r\n\r\n<p>For the second test case, the hidden integer is $2$. The questions and the corresponding answers are as follows.<\/p>\r\n\r\n<ul>\r\n\t<li>When asked about $a=0$, $b=0$, the result is $\\sqrt{x-a}-b=\\sqrt{2}-0=\\sqrt{2}$. As this is positive, the interactor returns <span style=\"color:#e74c3c;\"><code><strong>+<\/strong><\/code><\/span>.<\/li>\r\n\t<li>When asked about $a=1$, $b=1$, the result is $\\sqrt{x-a}-b=\\sqrt{1}-1=0$. As this is exactly $0$, the interactor returns <span style=\"color:#e74c3c;\"><code><strong>0<\/strong><\/code><\/span>.<\/li>\r\n<\/ul>\r\n\r\n<p>As you can infer that $x=2$ at this point, you may output <span style=\"color:#e74c3c;\"><code><strong>! 2<\/strong><\/code><\/span> to secure the value of $x$.<\/p>\r\n"}]

출처

Contest > BOJ User Contest > 흐즈로컵 > 제3회 흐즈로컵 (The 3rd Chromate Cup) Algorithm Division G번

채점 및 기타 정보

  • 예제는 채점하지 않는다.
(追記) (追記ここまで)

출처

대학교 대회

  • 사업자 등록 번호: 541-88-00682
  • 대표자명: 최백준
  • 주소: 서울시 서초구 서초대로74길 29 서초파라곤 412호
  • 전화번호: 02-521-0487 (이메일로 연락 주세요)
  • 이메일: contacts@startlink.io
  • 통신판매신고번호: 제 2017-서울서초-2193 호

AltStyle によって変換されたページ (->オリジナル) /