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

33806번 - Sheriruth 서브태스크다국어인터랙티브

시간 제한메모리 제한제출정답맞힌 사람정답 비율
5 초 1024 MB75201659.259%

문제

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

주어진 양의 정수 $n\le 15$과, 1ドル\le m\le 2n$에 대해서, RUN game이라는 것은 "방어자"가 "공격자"의 공격을 방어하는 컨셉으로 이루어지는 2인용 경쟁 게임이다. 그 진행방식은 다음과 같이 기술된다:

  1. 방어자는 모든 1ドル\le t\le 2^n-1$에 대해서, $t$의 길이 $n$의 이진전개를 $A_t$이라고 할 때, $A_t$에서 0ドル$인 값들을 적절히 2ドル$로 바꾸어 어떤 0ドル$부터 2ドル$ 사이의 값을 가지는 길이 $n$의 수열 $B_t$를 만든다.
  2. 공격자는 세 정수 1ドル\le x,y,z\le 2^n-1$를 선택한다. 이 세 정수는 $x+y+z=2^n-1$을 만족해야 하며, $x,y,z$중 어느 두 정수를 뽑더라도 이 둘의 bitwise AND는 0ドル$이어야 한다. 즉, $x,y,z$는 2ドル^n-1$의 비트를 적절히 나누어가진 세 정수여야 한다. 만약 이렇게 선택한 $x,y,z$에 대해서, 다음의 조건이 성립하지 않는다면 공격자는 이 세 정수의 이진전개를 선언하고 승리한다. 그렇지 않다면 방어자가 승리한다.

조건: 임의의 1ドル\le i\le n$에 대해서, $B_x,B_y,B_z$중 적어도 하나는 $i$번째 원소가 2ドル$이다. 또한, $B_x,B_y,B_z$에 속한 2ドル$의 개수의 총합이 $m$ 이하여야 한다.

히카리와 타이리츠는 RUN game을 플레이하려고 한다. 이들의 게임은 다음과 같이 진행될 것이다.

일단, 맨 처음 $n,m$이 주어지고 나면 타이리츠는 공격자를 할지 방어자를 할지 결정한다.

타이리츠가 방어자를 하기로 결정했다면, 일반적인 RUN game의 룰대로 타이리츠는 히카리에게 2ドル^n-1$개의 수열을 제공하고, 히카리는 그중 조건을 만족하지 않는 $x,y,z$를 찾는다.

그러나, 타이리츠가 공격자를 하기로 결정했다면, 타이리츠는 1ドル$ 이상 2ドル^n-1$ 이하인 $x$에 대해 히카리에게 다음과 같은 질문을 최대 20ドル$개 할 수 있다:

  • ? $A_x$: 히카리가 생각한 $B_x$를 반환받는다.

최대 20ドル$번의 질문 이내에 만약 타이리츠가 조건을 만족하지 않는 $x,y,z$를 찾았다면, 타이리츠는 그 이진전개를 선언하고 승리할 수 있다. 만약 20ドル$번 이내에 이를 찾지 못했다면, 히카리가 승리한다.

타이리츠의 전략을 수행하는 프로그램을 작성하여라.

인터랙션

맨 처음, 그레이더는 $n,m$을 공백으로 구분하여 프로그램에게 제공한다. 프로그램은 이를 받고, 방어자를 선택할 것이라면 0을, 공격자를 선택할 것이라면 1을 출력한다.

만약 방어자를 선택한 경우, 그 다음 $i$번째 줄에는 타이리츠가 결정할 $B_i$를 공백없이 출력한다.

만약 공격자를 선택한 경우, 프로그램은 1ドル$ 이상 2ドル^n-1$ 이하인 $x$에 대해 다음과 같은 쿼리에 대한 답을 최대 20ドル$번 받을 수 있다:

  • ? $A_x$: 히카리가 결정한 $B_x$가 공백없이 다음 줄에 입력된다.

만약 조건을 만족하지 않는 세 정수 $x,y,z$를 발견했다면,

  • ! $A_x$ $A_y$ $A_z$

과 같은 형식으로 세 정수의 이진전개를 출력하고 승리를 선언한다.

두 쿼리 전부에 대해서, 어떤 정수의 길이 $n$의 이진전개를 출력할 때에는, $n$개의 원소를 공백없이 한 줄에 출력한다. 매 질의 혹은 선언 이후에는 반드시 버퍼를 비워야 한다.

입력

출력

제한

  • 3ドル\le n\le 15$
  • 1ドル\le m\le 2n$

서브태스크

번호배점제한
110

$m=2n$

210

$n\le 3$

310

$n\le 5$

420

$n\le 7$

510

$n\le 10$

610

$n\le 12$

730

추가적인 제약 조건이 없다.

예제 입력 1

3 6

예제 출력 1

0
221
212
211
122
121
112
111

타이리츠는 $n=3,ドル $m=6$을 받고, 방어자를 선택하였다. 세 정수 $x=1,y=2,z=4$를 생각하자. 이들은 $x+y+z=7=2^n-1$을 만족하며, 이들 중 어느 두 개를 선택하여도 그 bitwise AND가 0ドル$이다. 또한, 이 세 정수는 "조건"을 만족하는데, 왜냐하면 임의의 1ドル\le i\le 3$에 대해서 $i$번 원소가 2ドル$인 수열이 있고, $B_1,B_2,B_4$의 2ドル$의 개수의 총합은 6ドル$인데, 이는 $m=6$을 초과하지 않기 때문이다.

예제 입력 2

3 2
021
212
100

예제 출력 2

1
? 001
? 010
? 100
! 010 001 100

해당 입출력은 인터랙션의 가독성을 위해 임의로 빈 줄을 추가한 것으로, 실제 인터랙션에서는 빈 줄을 입출력하는 것을 포함하지 않음에 유의하라.

노트

어떤 정수 0ドル\le t<2^n$에 대해서, $t$의 길이 $n$의 이진전개라는 것은 길이 $n$의 이진수열 $a_na_{n-1}...a_1$인데, 이때 $a_i$는 $\left\lfloor \frac{t}{2^{i-1}} \right\rfloor$가 홀수라면 1ドル$이고, 그렇지 않다면 0ドル$이다. 간단히 말해서, $a_i$는 $t$의 $i$번째 비트이다.

출력 버퍼를 비우는 방법은 다음과 같다.

  • C: fflush(stdout)
  • C++: std::cout << std::flush
  • Java: System.out.flush()
  • Python: sys.stdout.flush()

이외의 언어에 대해서는 언어별 명세를 참고해야 한다.

[{"problem_id":"33806","problem_lang":"0","title":"Sheriruth","description":"<p>\uc774 \ubb38\uc81c\ub294 <strong>\uc778\ud130\ub799\ud2f0\ube0c \ubb38\uc81c<\/strong>\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc8fc\uc5b4\uc9c4 \uc591\uc758 \uc815\uc218 $n\\le 15$\uacfc, $1\\le m\\le 2n$\uc5d0 \ub300\ud574\uc11c, <strong>RUN game<\/strong>\uc774\ub77c\ub294 \uac83\uc740 &quot;\ubc29\uc5b4\uc790&quot;\uac00 &quot;\uacf5\uaca9\uc790&quot;\uc758 \uacf5\uaca9\uc744 \ubc29\uc5b4\ud558\ub294 \ucee8\uc149\uc73c\ub85c \uc774\ub8e8\uc5b4\uc9c0\ub294 2\uc778\uc6a9 \uacbd\uc7c1 \uac8c\uc784\uc774\ub2e4. \uadf8 \uc9c4\ud589\ubc29\uc2dd\uc740 \ub2e4\uc74c\uacfc \uac19\uc774 \uae30\uc220\ub41c\ub2e4:<\/p>\r\n\r\n<ol>\r\n\t<li><strong>\ubc29\uc5b4\uc790<\/strong>\ub294 \ubaa8\ub4e0 $1\\le t\\le 2^n-1$\uc5d0 \ub300\ud574\uc11c, $t$\uc758 \uae38\uc774 $n$\uc758 \uc774\uc9c4\uc804\uac1c\ub97c $A_t$\uc774\ub77c\uace0 \ud560 \ub54c, $A_t$\uc5d0\uc11c $0$\uc778 \uac12\ub4e4\uc744 \uc801\uc808\ud788 $2$\ub85c \ubc14\uafb8\uc5b4 \uc5b4\ub5a4 $0$\ubd80\ud130 $2$ \uc0ac\uc774\uc758 \uac12\uc744 \uac00\uc9c0\ub294 \uae38\uc774 $n$\uc758 \uc218\uc5f4 $B_t$\ub97c \ub9cc\ub4e0\ub2e4.<\/li>\r\n\t<li><strong>\uacf5\uaca9\uc790<\/strong>\ub294 \uc138 \uc815\uc218 $1\\le x,y,z\\le 2^n-1$\ub97c \uc120\ud0dd\ud55c\ub2e4. \uc774 \uc138 \uc815\uc218\ub294 $x+y+z=2^n-1$\uc744 \ub9cc\uc871\ud574\uc57c \ud558\uba70, $x,y,z$\uc911 \uc5b4\ub290 \ub450 \uc815\uc218\ub97c \ubf51\ub354\ub77c\ub3c4 \uc774 \ub458\uc758 <strong>bitwise AND<\/strong>\ub294 $0$\uc774\uc5b4\uc57c \ud55c\ub2e4. \uc989, $x,y,z$\ub294 $2^n-1$\uc758 \ube44\ud2b8\ub97c \uc801\uc808\ud788 \ub098\ub204\uc5b4\uac00\uc9c4 \uc138 \uc815\uc218\uc5ec\uc57c \ud55c\ub2e4. \ub9cc\uc57d \uc774\ub807\uac8c \uc120\ud0dd\ud55c $x,y,z$\uc5d0 \ub300\ud574\uc11c, \ub2e4\uc74c\uc758 <strong>\uc870\uac74<\/strong>\uc774 \uc131\ub9bd\ud558\uc9c0 \uc54a\ub294\ub2e4\uba74 \uacf5\uaca9\uc790\ub294 \uc774 \uc138 \uc815\uc218\uc758 \uc774\uc9c4\uc804\uac1c\ub97c \uc120\uc5b8\ud558\uace0 \uc2b9\ub9ac\ud55c\ub2e4. \uadf8\ub807\uc9c0 \uc54a\ub2e4\uba74 \ubc29\uc5b4\uc790\uac00 \uc2b9\ub9ac\ud55c\ub2e4.<\/li>\r\n<\/ol>\r\n\r\n<p><strong>\uc870\uac74<\/strong>: \uc784\uc758\uc758 $1\\le i\\le n$\uc5d0 \ub300\ud574\uc11c, $B_x,B_y,B_z$\uc911 \uc801\uc5b4\ub3c4 \ud558\ub098\ub294 $i$\ubc88\uc9f8 \uc6d0\uc18c\uac00 $2$\uc774\ub2e4. \ub610\ud55c, $B_x,B_y,B_z$\uc5d0 \uc18d\ud55c $2$\uc758 \uac1c\uc218\uc758 \ucd1d\ud569\uc774 $m$ \uc774\ud558\uc5ec\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ud788\uce74\ub9ac\uc640 \ud0c0\uc774\ub9ac\uce20\ub294 RUN game\uc744 \ud50c\ub808\uc774\ud558\ub824\uace0 \ud55c\ub2e4. \uc774\ub4e4\uc758 \uac8c\uc784\uc740 \ub2e4\uc74c\uacfc \uac19\uc774 \uc9c4\ud589\ub420 \uac83\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc77c\ub2e8, \ub9e8 \ucc98\uc74c $n,m$\uc774 \uc8fc\uc5b4\uc9c0\uace0 \ub098\uba74 \ud0c0\uc774\ub9ac\uce20\ub294 \uacf5\uaca9\uc790\ub97c \ud560\uc9c0 \ubc29\uc5b4\uc790\ub97c \ud560\uc9c0 \uacb0\uc815\ud55c\ub2e4.<\/p>\r\n\r\n<p>\ud0c0\uc774\ub9ac\uce20\uac00 \ubc29\uc5b4\uc790\ub97c \ud558\uae30\ub85c \uacb0\uc815\ud588\ub2e4\uba74, \uc77c\ubc18\uc801\uc778 RUN game\uc758 \ub8f0\ub300\ub85c \ud0c0\uc774\ub9ac\uce20\ub294 \ud788\uce74\ub9ac\uc5d0\uac8c $2^n-1$\uac1c\uc758 \uc218\uc5f4\uc744 \uc81c\uacf5\ud558\uace0, \ud788\uce74\ub9ac\ub294 \uadf8\uc911 \uc870\uac74\uc744 \ub9cc\uc871\ud558\uc9c0 \uc54a\ub294 $x,y,z$\ub97c \ucc3e\ub294\ub2e4.<\/p>\r\n\r\n<p>\uadf8\ub7ec\ub098, \ud0c0\uc774\ub9ac\uce20\uac00 \uacf5\uaca9\uc790\ub97c \ud558\uae30\ub85c \uacb0\uc815\ud588\ub2e4\uba74, \ud0c0\uc774\ub9ac\uce20\ub294 $1$ \uc774\uc0c1 $2^n-1$ \uc774\ud558\uc778 $x$\uc5d0 \ub300\ud574 \ud788\uce74\ub9ac\uc5d0\uac8c \ub2e4\uc74c\uacfc \uac19\uc740 \uc9c8\ubb38\uc744 \ucd5c\ub300 $20$\uac1c \ud560 \uc218 \uc788\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li><code>?<\/code> $A_x$: \ud788\uce74\ub9ac\uac00 \uc0dd\uac01\ud55c $B_x$\ub97c \ubc18\ud658\ubc1b\ub294\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ucd5c\ub300 $20$\ubc88\uc758 \uc9c8\ubb38 \uc774\ub0b4\uc5d0 \ub9cc\uc57d \ud0c0\uc774\ub9ac\uce20\uac00 \uc870\uac74\uc744 \ub9cc\uc871\ud558\uc9c0 \uc54a\ub294 $x,y,z$\ub97c \ucc3e\uc558\ub2e4\uba74, \ud0c0\uc774\ub9ac\uce20\ub294 \uadf8 \uc774\uc9c4\uc804\uac1c\ub97c \uc120\uc5b8\ud558\uace0 \uc2b9\ub9ac\ud560 \uc218 \uc788\ub2e4. \ub9cc\uc57d $20$\ubc88 \uc774\ub0b4\uc5d0 \uc774\ub97c \ucc3e\uc9c0 \ubabb\ud588\ub2e4\uba74, \ud788\uce74\ub9ac\uac00 \uc2b9\ub9ac\ud55c\ub2e4.<\/p>\r\n\r\n<p>\ud0c0\uc774\ub9ac\uce20\uc758 \uc804\ub7b5\uc744 \uc218\ud589\ud558\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\uc5ec\ub77c.<\/p>\r\n","input":"","output":"","hint":"<p>\uc5b4\ub5a4 \uc815\uc218 $0\\le t&lt;2^n$\uc5d0 \ub300\ud574\uc11c, $t$\uc758 \uae38\uc774 $n$\uc758 \uc774\uc9c4\uc804\uac1c\ub77c\ub294 \uac83\uc740 \uae38\uc774 $n$\uc758 \uc774\uc9c4\uc218\uc5f4 $a_na_{n-1}...a_1$\uc778\ub370, \uc774\ub54c $a_i$\ub294 $\\left\\lfloor \\frac{t}{2^{i-1}} \\right\\rfloor$\uac00 \ud640\uc218\ub77c\uba74 $1$\uc774\uace0, \uadf8\ub807\uc9c0 \uc54a\ub2e4\uba74 $0$\uc774\ub2e4. \uac04\ub2e8\ud788 \ub9d0\ud574\uc11c, $a_i$\ub294 $t$\uc758 $i$\ubc88\uc9f8 \ube44\ud2b8\uc774\ub2e4.<\/p>\r\n\r\n<p>\ucd9c\ub825 \ubc84\ud37c\ub97c \ube44\uc6b0\ub294 \ubc29\ubc95\uc740 \ub2e4\uc74c\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>C: <span style=\"color:#e74c3c;\"><code>fflush(stdout)<\/code><\/span><\/li>\r\n\t<li>C++: <span style=\"color:#e74c3c;\"><code>std::cout &lt;&lt; std::flush<\/code><\/span><\/li>\r\n\t<li>Java: <span style=\"color:#e74c3c;\"><code>System.out.flush()<\/code><\/span><\/li>\r\n\t<li>Python: <span style=\"color:#e74c3c;\"><code>sys.stdout.flush()<\/code><\/span><\/li>\r\n<\/ul>\r\n\r\n<p>\uc774\uc678\uc758 \uc5b8\uc5b4\uc5d0 \ub300\ud574\uc11c\ub294 \uc5b8\uc5b4\ubcc4 \uba85\uc138\ub97c \ucc38\uace0\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$3\\le n\\le 15$<\/li>\r\n\t<li>$1\\le m\\le 2n$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$m=2n$<\/p>\r\n","subtask2":"<p>$n\\le 3$<\/p>\r\n","subtask3":"<p>$n\\le 5$<\/p>\r\n","subtask4":"<p>$n\\le 7$<\/p>\r\n","subtask5":"<p>$n\\le 10$<\/p>\r\n","subtask6":"<p>$n\\le 12$<\/p>\r\n","subtask7":"<p>\ucd94\uac00\uc801\uc778 \uc81c\uc57d \uc870\uac74\uc774 \uc5c6\ub2e4.<\/p>\r\n","custom_inter":"<p>\ub9e8 \ucc98\uc74c, \uadf8\ub808\uc774\ub354\ub294 $n,m$\uc744 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ud558\uc5ec \ud504\ub85c\uadf8\ub7a8\uc5d0\uac8c \uc81c\uacf5\ud55c\ub2e4. \ud504\ub85c\uadf8\ub7a8\uc740 \uc774\ub97c \ubc1b\uace0, \ubc29\uc5b4\uc790\ub97c \uc120\ud0dd\ud560 \uac83\uc774\ub77c\uba74 <code><span style=\"color:#e74c3c;\">0<\/span><\/code>\uc744, \uacf5\uaca9\uc790\ub97c \uc120\ud0dd\ud560 \uac83\uc774\ub77c\uba74 <code><span style=\"color:#e74c3c;\">1<\/span><\/code>\uc744 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<p>\ub9cc\uc57d \ubc29\uc5b4\uc790\ub97c \uc120\ud0dd\ud55c \uacbd\uc6b0, \uadf8 \ub2e4\uc74c $i$\ubc88\uc9f8 \uc904\uc5d0\ub294 \ud0c0\uc774\ub9ac\uce20\uac00 \uacb0\uc815\ud560 $B_i$\ub97c \uacf5\ubc31\uc5c6\uc774 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<p>\ub9cc\uc57d \uacf5\uaca9\uc790\ub97c \uc120\ud0dd\ud55c \uacbd\uc6b0, \ud504\ub85c\uadf8\ub7a8\uc740 $1$ \uc774\uc0c1 $2^n-1$ \uc774\ud558\uc778 $x$\uc5d0 \ub300\ud574 \ub2e4\uc74c\uacfc \uac19\uc740 \ucffc\ub9ac\uc5d0 \ub300\ud55c \ub2f5\uc744 \ucd5c\ub300 $20$\ubc88 \ubc1b\uc744 \uc218 \uc788\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li><code>?<\/code> $A_x$: \ud788\uce74\ub9ac\uac00 \uacb0\uc815\ud55c $B_x$\uac00 \uacf5\ubc31\uc5c6\uc774 \ub2e4\uc74c \uc904\uc5d0 \uc785\ub825\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ub9cc\uc57d \uc870\uac74\uc744 \ub9cc\uc871\ud558\uc9c0 \uc54a\ub294 \uc138 \uc815\uc218 $x,y,z$\ub97c \ubc1c\uacac\ud588\ub2e4\uba74,<\/p>\r\n\r\n<ul>\r\n\t<li><code>!<\/code> $A_x$ $A_y$ $A_z$<\/li>\r\n<\/ul>\r\n\r\n<p>\uacfc \uac19\uc740 \ud615\uc2dd\uc73c\ub85c \uc138 \uc815\uc218\uc758 \uc774\uc9c4\uc804\uac1c\ub97c \ucd9c\ub825\ud558\uace0 \uc2b9\ub9ac\ub97c \uc120\uc5b8\ud55c\ub2e4.<\/p>\r\n\r\n<p>\ub450 \ucffc\ub9ac \uc804\ubd80\uc5d0 \ub300\ud574\uc11c, \uc5b4\ub5a4 \uc815\uc218\uc758 \uae38\uc774 $n$\uc758 \uc774\uc9c4\uc804\uac1c\ub97c \ucd9c\ub825\ud560 \ub54c\uc5d0\ub294, $n$\uac1c\uc758 \uc6d0\uc18c\ub97c \uacf5\ubc31\uc5c6\uc774 \ud55c \uc904\uc5d0 \ucd9c\ub825\ud55c\ub2e4. \ub9e4 \uc9c8\uc758 \ud639\uc740 \uc120\uc5b8 \uc774\ud6c4\uc5d0\ub294 \ubc18\ub4dc\uc2dc <strong>\ubc84\ud37c\ub97c \ube44\uc6cc\uc57c \ud55c\ub2e4.<\/strong><\/p>\r\n","sample_explain_1":"<p>\ud0c0\uc774\ub9ac\uce20\ub294 $n=3$, $m=6$\uc744 \ubc1b\uace0, \ubc29\uc5b4\uc790\ub97c \uc120\ud0dd\ud558\uc600\ub2e4. \uc138 \uc815\uc218 $x=1,y=2,z=4$\ub97c \uc0dd\uac01\ud558\uc790. \uc774\ub4e4\uc740 $x+y+z=7=2^n-1$\uc744 \ub9cc\uc871\ud558\uba70, \uc774\ub4e4 \uc911 \uc5b4\ub290 \ub450 \uac1c\ub97c \uc120\ud0dd\ud558\uc5ec\ub3c4 \uadf8 bitwise AND\uac00 $0$\uc774\ub2e4. \ub610\ud55c, \uc774 \uc138 \uc815\uc218\ub294 &quot;\uc870\uac74&quot;\uc744 \ub9cc\uc871\ud558\ub294\ub370, \uc65c\ub0d0\ud558\uba74 \uc784\uc758\uc758 $1\\le i\\le 3$\uc5d0 \ub300\ud574\uc11c $i$\ubc88 \uc6d0\uc18c\uac00 $2$\uc778 \uc218\uc5f4\uc774 \uc788\uace0, $B_1,B_2,B_4$\uc758 $2$\uc758 \uac1c\uc218\uc758 \ucd1d\ud569\uc740 $6$\uc778\ub370, \uc774\ub294 $m=6$\uc744 \ucd08\uacfc\ud558\uc9c0 \uc54a\uae30 \ub54c\ubb38\uc774\ub2e4.<\/p>\r\n","sample_explain_2":"<p>\ud574\ub2f9 \uc785\ucd9c\ub825\uc740 \uc778\ud130\ub799\uc158\uc758 \uac00\ub3c5\uc131\uc744 \uc704\ud574 \uc784\uc758\ub85c \ube48 \uc904\uc744 \ucd94\uac00\ud55c \uac83\uc73c\ub85c, \uc2e4\uc81c \uc778\ud130\ub799\uc158\uc5d0\uc11c\ub294 \ube48 \uc904\uc744 \uc785\ucd9c\ub825\ud558\ub294 \uac83\uc744 \ud3ec\ud568\ud558\uc9c0 \uc54a\uc74c\uc5d0 \uc720\uc758\ud558\ub77c.<\/p>\r\n"},{"problem_id":"33806","problem_lang":"1","title":"Sheriruth","description":"<p>This problem is an <strong>interactive<\/strong> problem.<\/p>\r\n\r\n<p>Given a positive integer $n \\le 15$ and $1 \\le m \\le 2n$, the <strong>RUN game<\/strong>&nbsp;is a two-player competitive game with the concept of a &ldquo;defender&rdquo; protecting against an &ldquo;attacker&rsquo;s&rdquo; actions. The game proceeds as follows:<\/p>\r\n\r\n<ol>\r\n\t<li>For every integer $1 \\le t \\le 2^n - 1$,<strong>&nbsp;the<\/strong> <strong>defender<\/strong>&nbsp;defines $A_t$ as the length-$n$ binary representation of $t$\u200b. Then, by&nbsp;replacing some of the $0$&#39;s in $A_t$\u200b with $2$&#39;s, the defender constructs a sequence $B_t$\u200b of length $n$, where each element is an integer between $0$ and $2$.<\/li>\r\n\t<li><strong>The attacker<\/strong> selects three integers $1 \\le x, y, z \\le 2^n - 1$. These three integers should satisfy $x+y+z=2^n-1$, and for any two integers chosen from $x$, $y$, and $z$, their <strong>bitwise AND<\/strong>&nbsp;must be $0$ (that is, the bit representations of $x$, $y$, and $z$ partition the bits of $2^n - 1$.). If, for the selected $x$, $y$, and $z$, the following <strong>condition<\/strong>&nbsp;is not satisfied, the attacker declares the binary representations of $x$, $y$, and $z$, and wins. Otherwise, the defender wins.<\/li>\r\n<\/ol>\r\n\r\n<p><strong>Condition<\/strong>: For every $1 \\le i \\le n$, at least one of $B_x$, $B_y$, or $B_z$ must have the value&nbsp;$2$ at the $i$-th position. Also, the total number of $2$s in $B_x$, $B_y$, and $B_z$ must be at most $m$.&nbsp;<\/p>\r\n\r\n<p>Hikari and Tairitsu are going to play the RUN game. Their game proceeds as follows.<\/p>\r\n\r\n<p>First of all,&nbsp;after receiving $n$ and $m$, Tairitsu decides whether to be the attacker or the defender.<\/p>\r\n\r\n<p>If Tairitsu chooses to be the defender,&nbsp;then according to the regular rules of the RUN game, Tairitsu provides Hikari with $2^n - 1$ sequences $b_t$. Hikari then tries to find $x, y, z$ that violate the condition.<\/p>\r\n\r\n<p>If Tairitsu chooses to be the attacker, Tairitsu may ask Hikari up to $20$ queries in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li><code>?<\/code>&nbsp;$A_x$:&nbsp;Hikari responds with the sequence $B_x$.<\/li>\r\n<\/ul>\r\n\r\n<p>If, within at most $20$ queries, Tairitsu finds values $x$, $y$, and $z$ that violate the condition, Tairitsu may declare their binary representations and&nbsp;win the game.&nbsp;If Tairitsu cannot find such a triple within $20$ queries, then Hikari wins.<\/p>\r\n\r\n<p>Write a program that performs Tairitsu&rsquo;s strategy.<\/p>\r\n","input":"","output":"","hint":"<p>For any integer $0 \\le t &lt; 2^n$, the length-$n$ binary representation of $t$ is the binary sequence $a_n a_{n-1} \\dots a_1$, where $a_i$ is the $i$-th bit of $t$.<\/p>\r\n\r\n<p>You can flush the output buffer by using the following methods:<\/p>\r\n\r\n<ul>\r\n\t<li>C: <span style=\"color:#e74c3c;\"><code>fflush(stdout)<\/code><\/span><\/li>\r\n\t<li>C++: <span style=\"color:#e74c3c;\"><code>std::cout &lt;&lt; std::flush<\/code><\/span><\/li>\r\n\t<li>Java: <span style=\"color:#e74c3c;\"><code>System.out.flush()<\/code><\/span><\/li>\r\n\t<li>Python: <span style=\"color:#e74c3c;\"><code>sys.stdout.flush()<\/code><\/span><\/li>\r\n<\/ul>\r\n\r\n<p>For other languages, you should refer to the language-specific specifications.<\/p>\r\n","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$3\\le n\\le 15$<\/li>\r\n\t<li>$1\\le m\\le 2n$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$m=2n$<\/p>\r\n","subtask2":"<p>$n\\le 3$<\/p>\r\n","subtask3":"<p>$n\\le 5$<\/p>\r\n","subtask4":"<p>$n\\le 7$<\/p>\r\n","subtask5":"<p>$n\\le 10$<\/p>\r\n","subtask6":"<p>$n\\le 12$<\/p>\r\n","subtask7":"<p>No additional constraints.<\/p>\r\n","custom_inter":"<p>First, the grader provides the values of $n$ and $m$ separated by a space. The program receives this input and should output <code><span style=\"color:#e74c3c;\">0<\/span><\/code> if it chooses to be the defender, or <code><span style=\"color:#e74c3c;\">1<\/span> <\/code>if it chooses to be the attacker.<\/p>\r\n\r\n<p>If the program chooses to be the defender, then the program should output each $B_i$ (as determined by Tairitsu) on the $i$-th line, without spaces.<\/p>\r\n\r\n<p>If the program chooses to be the attacker, your program may perform up to $20$ queries in the form<\/p>\r\n\r\n<ul>\r\n\t<li><code>?<\/code> $A_x$: The sequence $B_x$ chosen by Hikari is given on the next line, without spaces.<\/li>\r\n<\/ul>\r\n\r\n<p>If a violating triple $x,y,z$ is found, print them in the form<\/p>\r\n\r\n<ul>\r\n\t<li><code>!<\/code> $A_x$ $A_y$ $A_z$<\/li>\r\n<\/ul>\r\n\r\n<p>and declare victory.<\/p>\r\n\r\n<p>For both types of queries, when outputting the binary representation of a number of length $n$, you must print the $n$ binary digits on a single line without spaces. After each query or declaration, you <strong>must flush the output buffer<\/strong>.<\/p>\r\n","sample_explain_1":"<p>Tairitsu receives $n = 3$, $m = 6$, and chooses to be the defender. Consider the three integers $x = 1$, $y = 2$, and $z = 4$. They satisfy $x + y + z = 7 = 2^n - 1$, and the bitwise AND of any two of them is 0. These three integers also satisfy the condition, because for every $1 \\le i \\le 3$, at least at least one of the sequences among $B_1$, $B_2$, and $B_4$ has 2 at the iii-th position, and the total number of 2s in $B_1$, $B_2$, and $B_4$ is 6, which does not exceed $m = 6$. Therefore, Hikari cannot win by declaring these three integers.<\/p>\r\n","sample_explain_2":"<p>Note that any blank lines in the sample input\/output are added solely for readability of the interaction; actual interactions must not include any blank lines in input or output.<\/p>\r\n"}]

출처

University > KAIST > KAIST RUN Spring Contest > 2025 KAIST RUN Spring Contest G번

채점 및 기타 정보

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

출처

대학교 대회

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

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