시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 1024 MB59213110126.031%

문제

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

한별이와 우빈이는 같은 기숙사 방을 배정받게 되었다. 그런데 한별이와 같은 방을 쓰기 부끄러웠던 우빈이는 한별이가 들어오기 전 문에다가 비밀번호 장치를 설치해 버렸다. 장치를 풀기 위해선 $0 \leq x_{i} < 998\,244\,353$를 만족하는 $N$개의 정수 $x_{1},x_{2},\cdots,x_{N}$를 알아내야 한다. 그러나 츤데레인 우빈이는 한별이의 프로그래밍 실력이 뛰어난지 알아보기 위하여 다음의 함수를 제공하였다. 한별이는 $N$개의 원하는 정수 $a_{1},a_{2},\cdots,a_{N}$을 골라 그 함숫값 $f(a_{1},a_{2},\cdots,a_{N})$을 알아낼 수 있다.

$0$ 이상 $998\,244\,353$ 미만의 정수들의 집합을 $\mathbb{M}$이라고 할 때, 함수 $f: {\overbrace{\mathbb M \times \mathbb M \times \cdots \times \mathbb M}^{N\text{ times}}} \rightarrow \mathbb{M}$은 다음과 같이 정의된다: $$f(a_{1},a_{2},\cdots,a_{N})=(a_{1}x_{1}+a_{2}x_{2}+\cdots+a_{N}x_{N}) \bmod 998\,244\,353$$

단, 함수는 최대 $N$번만 사용할 수 있으며, 모든 함수 사용을 통틀어서 $a_{1}, a_{2}, \ldots, a_{N}$는 전부 달라야 한다. 즉, 함수를 $k$번 사용했다면 $kN$개의 인자가 모두 달라야 한다.

이제 비밀번호를 구하여 우빈이를 놀래켜 보자.

인터랙션

당신의 프로그램은 아래의 과정을 통해 표준입력과 표준출력으로 인터랙터와 상호작용해야 한다.

먼저, 입력의 첫 번째 줄에 정수 $N$이 주어진다.

아래 쿼리를 출력하면 다음 줄에 $f(a_{1},\cdots,a_{N})$의 값이 주어진다. 이 쿼리는 최대 $N$번만 사용할 수 있다.

  • ? $a_1$ $a_2$ $a_3$ $\cdots$ $a_N$ (단, $0 \leq a_{i} < 998\,244\,353$)

아래 쿼리를 출력해서 비밀번호를 제출할 수 있다. 이 쿼리를 출력한 직후 프로그램을 종료해야 한다.

  • ! $x_1$ $x_2$ $x_3$ $\cdots$ $x_N$ (단, $0 \leq x_{i} < 998\,244\,353$)

각 채점 데이터에 대하여, 제출한 비밀번호가 정답이라면 맞았습니다!!, 오답이라면 틀렸습니다 결과를 받는다. 단, 문제의 제한 안에 올바른 상호작용을 통해 답을 출력하지 못하면 예상치 못한 채점 결과를 받을 수 있다.

제한

  • $2 \leq N \leq 2500$

서브태스크

번호배점제한
110

$N \leq 100$

290

추가 제약 조건 없음

예제 입력 1

2

4

6

예제 출력 1


? 1 3

? 2 4

! 1 1

노트

당신의 프로그램은 무언가를 출력한 후 즉시 출력 버퍼를 비워야 한다. 다음은 언어별 출력 버퍼를 비우는 방법이다.

  • C — fflush(stdout)
  • C++ — std::cout.flush()
  • Python — sys.stdout.flush()
  • Java — System.out.flush()
  • 그 외의 언어는 각 언어의 Documentation을 참고한다.

또한, 예제의 빈 줄은 입출력이 어떤 방식으로 이루어지는지 이해를 돕기 위해 의도적으로 추가된 것이며, 실제 입출력에는 빈 줄이 나타나지 않는다.

[{"problem_id":"31435","problem_lang":"0","title":"\uae30\uc219\uc0ac \ube44\ubc00\ubc88\ud638 \uad6c\ud558\uae30","description":"<p>\uc774 \ubb38\uc81c\ub294 <strong>\uc778\ud130\ub799\ud2f0\ube0c<\/strong> \ubb38\uc81c\uc774\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/216686e3-9a60-4d29-ac8c-aa3f44a59255\/-\/preview\/\" style=\"width: 768px; height: 567px;\" \/><\/p>\r\n\r\n<p>\ud55c\ubcc4\uc774\uc640 \uc6b0\ube48\uc774\ub294 \uac19\uc740 \uae30\uc219\uc0ac \ubc29\uc744 \ubc30\uc815\ubc1b\uac8c \ub418\uc5c8\ub2e4. \uadf8\ub7f0\ub370 \ud55c\ubcc4\uc774\uc640 \uac19\uc740 \ubc29\uc744 \uc4f0\uae30 \ubd80\ub044\ub7ec\uc6e0\ub358 \uc6b0\ube48\uc774\ub294 \ud55c\ubcc4\uc774\uac00 \ub4e4\uc5b4\uc624\uae30 \uc804 \ubb38\uc5d0\ub2e4\uac00 \ube44\ubc00\ubc88\ud638 \uc7a5\uce58\ub97c \uc124\uce58\ud574 \ubc84\ub838\ub2e4. \uc7a5\uce58\ub97c \ud480\uae30 \uc704\ud574\uc120 $0 \\leq x_{i} &lt; 998\\,244\\,353$\ub97c \ub9cc\uc871\ud558\ub294 $N$\uac1c\uc758 \uc815\uc218 $x_{1},x_{2},\\cdots,x_{N}$\ub97c \uc54c\uc544\ub0b4\uc57c \ud55c\ub2e4. \uadf8\ub7ec\ub098 \uce24\ub370\ub808\uc778 \uc6b0\ube48\uc774\ub294 \ud55c\ubcc4\uc774\uc758 \ud504\ub85c\uadf8\ub798\ubc0d \uc2e4\ub825\uc774 \ub6f0\uc5b4\ub09c\uc9c0 \uc54c\uc544\ubcf4\uae30 \uc704\ud558\uc5ec \ub2e4\uc74c\uc758 \ud568\uc218\ub97c \uc81c\uacf5\ud558\uc600\ub2e4. \ud55c\ubcc4\uc774\ub294 $N$\uac1c\uc758 \uc6d0\ud558\ub294 \uc815\uc218 $a_{1},a_{2},\\cdots,a_{N}$\uc744 \uace8\ub77c \uadf8 \ud568\uc22b\uac12 $f(a_{1},a_{2},\\cdots,a_{N})$\uc744 \uc54c\uc544\ub0bc \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>$0$ \uc774\uc0c1 $998\\,244\\,353$ \ubbf8\ub9cc\uc758 \uc815\uc218\ub4e4\uc758 \uc9d1\ud569\uc744 $\\mathbb{M}$\uc774\ub77c\uace0 \ud560 \ub54c, \ud568\uc218 $f: {\\overbrace{\\mathbb M \\times \\mathbb M \\times \\cdots \\times \\mathbb M}^{N\\text{ times}}} \\rightarrow \\mathbb{M}$\uc740 \ub2e4\uc74c\uacfc \uac19\uc774 \uc815\uc758\ub41c\ub2e4: $$f(a_{1},a_{2},\\cdots,a_{N})=(a_{1}x_{1}+a_{2}x_{2}+\\cdots+a_{N}x_{N}) \\bmod 998\\,244\\,353$$<\/p>\r\n\r\n<p>\ub2e8, \ud568\uc218\ub294 \ucd5c\ub300 $N$\ubc88\ub9cc \uc0ac\uc6a9\ud560 \uc218 \uc788\uc73c\uba70, \ubaa8\ub4e0 \ud568\uc218 \uc0ac\uc6a9\uc744 \ud1b5\ud2c0\uc5b4\uc11c $a_{1}, a_{2}, \\ldots, a_{N}$\ub294 \uc804\ubd80 \ub2ec\ub77c\uc57c \ud55c\ub2e4. \uc989, \ud568\uc218\ub97c $k$\ubc88 \uc0ac\uc6a9\ud588\ub2e4\uba74 $kN$\uac1c\uc758 \uc778\uc790\uac00 \ubaa8\ub450 \ub2ec\ub77c\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc774\uc81c \ube44\ubc00\ubc88\ud638\ub97c \uad6c\ud558\uc5ec \uc6b0\ube48\uc774\ub97c \ub180\ub798\ucf1c \ubcf4\uc790.<\/p>\r\n","input":"","output":"","hint":"<p>\ub2f9\uc2e0\uc758 \ud504\ub85c\uadf8\ub7a8\uc740 \ubb34\uc5b8\uac00\ub97c \ucd9c\ub825\ud55c \ud6c4 \uc989\uc2dc \ucd9c\ub825 \ubc84\ud37c\ub97c \ube44\uc6cc\uc57c \ud55c\ub2e4. \ub2e4\uc74c\uc740 \uc5b8\uc5b4\ubcc4 \ucd9c\ub825 \ubc84\ud37c\ub97c \ube44\uc6b0\ub294 \ubc29\ubc95\uc774\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>C &mdash; <span style=\"color:#e74c3c;\"><code>fflush(stdout)<\/code><\/span><\/li>\r\n\t<li>C++ &mdash; <span style=\"color:#e74c3c;\"><code>std::cout.flush()<\/code><\/span><\/li>\r\n\t<li>Python &mdash; <span style=\"color:#e74c3c;\"><code>sys.stdout.flush()<\/code><\/span><\/li>\r\n\t<li>Java &mdash; <span style=\"color:#e74c3c;\"><code>System.out.flush()<\/code><\/span><\/li>\r\n\t<li>\uadf8 \uc678\uc758 \uc5b8\uc5b4\ub294 \uac01 \uc5b8\uc5b4\uc758 Documentation\uc744 \ucc38\uace0\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ub610\ud55c, \uc608\uc81c\uc758 \ube48 \uc904\uc740 \uc785\ucd9c\ub825\uc774 \uc5b4\ub5a4 \ubc29\uc2dd\uc73c\ub85c \uc774\ub8e8\uc5b4\uc9c0\ub294\uc9c0 \uc774\ud574\ub97c \ub3d5\uae30 \uc704\ud574 \uc758\ub3c4\uc801\uc73c\ub85c \ucd94\uac00\ub41c \uac83\uc774\uba70, \uc2e4\uc81c \uc785\ucd9c\ub825\uc5d0\ub294 \ube48 \uc904\uc774 \ub098\ud0c0\ub098\uc9c0 \uc54a\ub294\ub2e4.<\/p>\r\n","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$2 \\leq N \\leq 2500$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N \\leq 100$<\/p>\r\n","subtask2":"<p>\ucd94\uac00 \uc81c\uc57d \uc870\uac74 \uc5c6\uc74c<\/p>\r\n","custom_interac":"<p>\ub2f9\uc2e0\uc758 \ud504\ub85c\uadf8\ub7a8\uc740 \uc544\ub798\uc758 \uacfc\uc815\uc744 \ud1b5\ud574 \ud45c\uc900\uc785\ub825\uacfc \ud45c\uc900\ucd9c\ub825\uc73c\ub85c \uc778\ud130\ub799\ud130\uc640 \uc0c1\ud638\uc791\uc6a9\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uba3c\uc800, \uc785\ub825\uc758 \uccab \ubc88\uc9f8 \uc904\uc5d0 \uc815\uc218 $N$\uc774 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uc544\ub798 \ucffc\ub9ac\ub97c \ucd9c\ub825\ud558\uba74 \ub2e4\uc74c \uc904\uc5d0 $f(a_{1},\\cdots,a_{N})$\uc758 \uac12\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. \uc774 \ucffc\ub9ac\ub294 \ucd5c\ub300 $N$\ubc88\ub9cc \uc0ac\uc6a9\ud560 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li><span style=\"color:#e74c3c;\"><code>? <\/code>$a_1$<code> <\/code>$a_2$<code> <\/code>$a_3$<code> <\/code>$\\cdots$<code> <\/code>$a_N$<code> <\/code><\/span>(\ub2e8, $0 \\leq a_{i} &lt; 998\\,244\\,353$)<\/li>\r\n<\/ul>\r\n\r\n<p>\uc544\ub798 \ucffc\ub9ac\ub97c \ucd9c\ub825\ud574\uc11c \ube44\ubc00\ubc88\ud638\ub97c \uc81c\ucd9c\ud560 \uc218 \uc788\ub2e4. \uc774 \ucffc\ub9ac\ub97c \ucd9c\ub825\ud55c \uc9c1\ud6c4 \ud504\ub85c\uadf8\ub7a8\uc744 \uc885\ub8cc\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li><span style=\"color:#e74c3c;\"><code>! <\/code>$x_1$<code> <\/code>$x_2$<code> <\/code>$x_3$<code> <\/code>$\\cdots$<code> <\/code>$x_N$<\/span><code> <\/code>(\ub2e8, $0 \\leq x_{i} &lt; 998\\,244\\,353$)<\/li>\r\n<\/ul>\r\n\r\n<p>\uac01 \ucc44\uc810 \ub370\uc774\ud130\uc5d0 \ub300\ud558\uc5ec, \uc81c\ucd9c\ud55c \ube44\ubc00\ubc88\ud638\uac00 \uc815\ub2f5\uc774\ub77c\uba74 <strong><span style=\"color:#009874;\">\ub9de\uc558\uc2b5\ub2c8\ub2e4!!<\/span><\/strong>, \uc624\ub2f5\uc774\ub77c\uba74 <span style=\"color:#dd4124;\">\ud2c0\ub838\uc2b5\ub2c8\ub2e4<\/span> \uacb0\uacfc\ub97c \ubc1b\ub294\ub2e4. \ub2e8, \ubb38\uc81c\uc758 \uc81c\ud55c \uc548\uc5d0 \uc62c\ubc14\ub978 \uc0c1\ud638\uc791\uc6a9\uc744 \ud1b5\ud574 \ub2f5\uc744 \ucd9c\ub825\ud558\uc9c0 \ubabb\ud558\uba74 \uc608\uc0c1\uce58 \ubabb\ud55c \ucc44\uc810 \uacb0\uacfc\ub97c \ubc1b\uc744 \uc218 \uc788\ub2e4. <\/p>\r\n"},{"problem_id":"31435","problem_lang":"1","title":"Get the Dormitory Passcode","description":"<p>This&nbsp;is an <strong>interactive<\/strong>&nbsp;problem.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/216686e3-9a60-4d29-ac8c-aa3f44a59255\/-\/preview\/\" style=\"width: 768px; height: 567px;\" \/><\/p>\r\n\r\n<p>Hanbyeol and Woobin have been assigned to the same dormitory room. However, Woobin, who was embarrassed to share the room with Hanbyeol, installed a passcode device on the door before Hanbyeol came in. To unlock the device, Hanbyeol needs to find $N$ integers $x_{1},x_{2},\\cdots,x_{N}$ that satisfy $0 \\leq x_{i} &lt; 998\\,244\\,353$. However, the tsundere Woobin provided the following function to assess Hanbyeol&#39;s programming skills. Hanbyeol can determine the function value $f(a_{1},a_{2},\\cdots,a_{N})$&nbsp;after&nbsp;choosing $N$&nbsp;desired integers $a_{1},a_{2},\\cdots,a_{N}$.<\/p>\r\n\r\n<p>Let $\\mathbb{M}$ be the set of all integers $x$ such that $0 \\leq x &lt; 998\\,244\\,353$. The function $f: {\\overbrace{\\mathbb M \\times \\mathbb M \\times \\cdots \\times \\mathbb M}^{N\\text{ times}}}&nbsp;\\rightarrow \\mathbb{M}$ is defined as follows: $$f(a_{1},a_{2},\\cdots,a_{N})=(a_{1}x_{1}+a_{2}x_{2}+\\cdots+a_{N}x_{N}) \\bmod 998\\,244\\,353$$<\/p>\r\n\r\n<p>However, the function can only be used up to $N$ times, and all the variables $a_{1}, a_{2}, \\ldots, a_{N}$ used in all the function operations must be different. In other words, if the function is used $k$&nbsp;times, all $kN$&nbsp;arguments must be different.<\/p>\r\n\r\n<p>Now, let&#39;s find the passcode and surprise Woobin.<\/p>\r\n","input":"","output":"","hint":"<p>You must flush the output immediately after printing something. To flush you can use:<\/p>\r\n\r\n<ul>\r\n\t<li>C &mdash;&nbsp;<span style=\"color:#e74c3c;\"><code>fflush(stdout)<\/code><\/span><\/li>\r\n\t<li>C++ &mdash;&nbsp;<span style=\"color:#e74c3c;\"><code>std::cout.flush()<\/code><\/span><\/li>\r\n\t<li>Python &mdash;&nbsp;<span style=\"color:#e74c3c;\"><code>sys.stdout.flush()<\/code><\/span><\/li>\r\n\t<li>Java &mdash;&nbsp;<span style=\"color:#e74c3c;\"><code>System.out.flush()<\/code><\/span><\/li>\r\n\t<li>read the documentation for other languages.<\/li>\r\n<\/ul>\r\n\r\n<p>Also, note that the empty lines in the example input and output are for the sake of clarity, and do not occur in the real interaction.<\/p>\r\n","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$2 \\leq N \\leq 2500$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N \\leq 100$<\/p>\r\n","subtask2":"<p>No additional constraints<\/p>\r\n","custom_interac":"<p>Your program should interact with the interactor through standard input and standard output as follows.<\/p>\r\n\r\n<p>First, an integer $N$ is given on the first line of the input.<\/p>\r\n\r\n<p>Upon outputting the following query, the value of $f(a_{1},\\cdots,a_{N})$ is given on the next line. This query can be used up to $N$ times.<\/p>\r\n\r\n<ul>\r\n\t<li><span style=\"color:#e74c3c;\"><code>? <\/code>$a_1$<code> <\/code>$a_2$<code> <\/code>$a_3$<code> <\/code>$\\cdots$<code> <\/code>$a_N$<code> <\/code><\/span>(where $0 \\leq a_{i} &lt; 998\\,244\\,353$)<\/li>\r\n<\/ul>\r\n\r\n<p>You can submit the password by outputting the following query. The program must terminate immediately after outputting this query.<\/p>\r\n\r\n<ul>\r\n\t<li><span style=\"color:#e74c3c;\"><code>! <\/code>$x_1$<code> <\/code>$x_2$<code> <\/code>$x_3$<code> <\/code>$\\cdots$<code> <\/code>$x_N$<\/span><code> <\/code>(where $0 \\leq x_{i} &lt; 998\\,244\\,353$)<\/li>\r\n<\/ul>\r\n\r\n<p>For each test case, if the submitted password is correct, you will receive <strong><span style=\"color:#009874;\">Accepted<\/span><\/strong>; if it is incorrect, you will receive <span style=\"color:#dd4124;\">Wrong Answer<\/span>. However, unexpected results may happen if you do not print the solution through proper interactions in the limitations of the problem provided.<\/p>\r\n"}]

채점 및 기타 정보

  • 예제는 채점하지 않는다.