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

25439번 - 죄수들의 도전 서브태스크점수다국어언어 제한함수 구현

시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 1024 MB258695928.922%

문제

감옥에 500ドル$명의 죄수가 갇혀 있다. 어느날, 간수는 감옥에서 나갈 수 있는 기회를 주었다. 간수가 방 안에 동전이 든 두 개의 가방 A와 B를 놓았다. 각 가방에는 1ドル$ 개 이상 $N$ 개 이하의 동전이 들어 있다. 두 가방에 든 동전의 개수는 다르다. 간수는 죄수들에게 도전 기회를 준다. 죄수들의 목표는 동전이 적게 든 가방을 찾는 것이다.

방에는 동전이 든 가방 외에도 칠판이 있다. 칠판에는 항상 정수 하나만 쓸 수 있다. 처음에는 칠판에 0ドル$이 쓰여 있다.

간수는 죄수들에게 한명씩 차례로 방에 들어오게 한다. 모든 죄수는 다른 죄수중 누가 자기보다 먼저 이 방에 들어 왔는지 알지 못하고, 또 자기 앞에 몇 명의 죄수가 방에 들어왔는지도 알지 못한다. 매번 죄수가 방에 들어올 때마다, 칠판에 쓰여진 정수를 읽는다. 이 정수를 읽은 다음, 가방 A와 B 중 하나를 골라야 한다. 다음 이 가방을 조사해서 이 가방에 몇 개의 동전이 있는지 알게 된다. 그 다음 죄수는 다음 두 행동 중 하나를 해야 한다.

  • 칠판에 쓰여진 정수를 지우고 음이 아닌 정수를 쓴 다음 방을 나간다. 칠판에 먼저 쓰여진 정수와 같은 정수를 쓸 수도 있고, 다른 정수를 쓸 수도 있다. 도전은 계속 이어진다. (500ドル$명의 죄수 모두가 방을 들어왔다가 나간 경우를 제외하고)
  • 동전이 적게 든 가방을 고르고 도전을 종료한다.

한번 방을 나간 죄수는 간수가 다시 방에 들여보내지 않는다.

만약 죄수 중 한 명이 동전이 적게 든 가방을 정확히 맞추면 죄수들이 도전에서 이긴다. 만약 죄수 중 한 명이라도 동전이 적게 든 가방을 틀리거나, 500ドル$명의 죄수 모두가 방에 들어갔다 나왔지만 동전이 적게 든 가방을 맞추려고 아무도 시도하지 않았다면 죄수들이 진다.

도전을 시작하기 전에, 죄수들은 강당에 모여서 3단계로 이루어지는 다음 공통 전략을 정했다.

  • 칠판에 쓸 수 있는 음이 아닌 정수의 최대값 $x$를 정한다.
  • 방에 들어갔을 때 칠판에 정수 $i$가 쓰여져 있다면 (0ドル \le i \le x$) 어느 가방을 조사할 것인지를 정한다.
  • 조사한 가방의 동전 개수를 알게 되면 어떤 행동을 할 것인지를 결정한다. 보다 구체적으로, 칠판에 정수 $i$가 쓰여져 있고 (0ドル \le i \le x$) 조사한 가방에 동전 $j$개가 들어 있다면, 다음 두 행동 중 하나를 하는 것으로 결정해야 한다.
    • 0ドル$ 이상 $x$ 이하인 어떤 정수를 칠판에 쓸 지, 또는
    • 어느 가방을 동전이 적은 쪽으로 고를지.

죄수들이 도전에서 이기면, 간수는 죄수들을 $x$일간 더 가둔 다음에 모두 풀어줄 것이다.

당신이 할 일은 죄수들이 이 도전을 이길 수 있는 전략을 고안하는 것이다. (가방 A, B에 있는 동전 개수와 무관하게) 여러분이 제출한 해법의 점수는 $x$의 값에 따라 달라진다. (자세한 내용은 Subtasks 참조)

구현

다음 함수를 구현해야 한다.

int[][] devise_strategy(int N)
  • $N$: 가방 하나에 들어갈 수 있는 동전의 최대 개수
  • 이 함수는 $N + 1$개의 정수를 저장하는 배열의 배열 $s$을 리턴해야 하며, 이 배열이 당신의 전략을 설명한다. $x$의 값은 배열 $s$의 길이에서 1을 뺀 값이다. 0ドル \le i \le x$인 각 $i$에 대해서, 배열 $s[i]$은 죄수가 방에 들어갔을 때 칠판에서 정수 $i$를 읽었다면 무엇을 해야 하는지를 나타낸다.
    1. 죄수가 만약 가방 A를 조사해봐야 하면 $s[i][0]$의 값은 0ドル$이고, 만약 가방 B를 조사해봐야 하면 1ドル$이다.
    2. $j$가 조사해본 가방에 들어 있는 동전 개수라고 하자. 그렇다면 죄수는 다음 행동을 해야 한다.
    • 만약 $s[i][j]$의 값이 $-1$이라면, 죄수는 가방 A를 동전이 적게 든 가방으로 고른다.
    • 만약 $s[i][j]$의 값이 $-2$이라면, 죄수는 가방 B를 동전이 적게 든 가방으로 고른다.
    • 만약 $s[i][j]$의 값이 음이 아니라면, 죄수는 이 정수를 칠판에 써야 한다. $s[i][j]$의 값은 최대 $x$라는데 주의하라.
  • 이 함수는 정확히 한 번 호출된다.

예제

다음 호출을 생각해보자.

devise_strategy(3)

$v$가 죄수가 방에 들어왔을 때 칠판에 쓰여진 정수라고 하자. 정답을 내는 전략 중 하나는 다음과 같다.

  • 만약 $v = 0$이라면 (처음 시작할 때를 포함해서), 가방 A를 조사한다.
    • 동전 1ドル$개가 들어 있다면, 가방 A를 동전이 적게 든 가방으로 고른다.
    • 동전 3ドル$개가 들어 있다면, 가방 B를 동전이 적게 든 가방으로 고른다.
    • 동전 2ドル$개가 들어 있다면, 칠판에 1ドル$을 쓴다. (0ドル$을 덮어쓴다.)
  • 만약 $v = 1$이라면 가방 B를 조사한다.
    • 동전 1ドル$개가 들어 있다면, 가방 B를 동전이 적게 든 가방으로 고른다.
    • 동전 3ドル$개가 들어 있다면, 가방 A를 동전이 적게 든 가방으로 고른다.
    • 동전 2ドル$개가 들어 있다면, 칠판에 0ドル$을 쓴다. (1ドル$을 덮어쓴다.) 이 경우는 절대 일어나지 않는다는데 주목하자. 왜냐하면 이때 두 가방 모두 동전 2ドル$개가 있는데, 두 가방에 같은 수의 동전이 들어 있는 것을 허용하지 않기 때문이다.

이 전략을 표현하려면 함수는 [[0, -1, 1, -2], [1, -2, 0, -1]]를 리턴해야 한다. 리턴된 배열의 길이는 2ドル$이고, $x$의 값은 2ドル - 1 = 1$이다.

입력

출력

제한

  • 2ドル \le N \le 5000$

서브태스크

번호배점제한
15

$N \le 500,ドル $x$는 500ドル$ 이하여야 한다.

25

$N \le 500,ドル $x$는 70ドル$ 이하여야 한다.

390

$x$는 60ドル$ 이하여야 한다.

만약 테스트 케이스 중 어느 경우에서든, devise_strategy가 리턴한 배열이 정확한 전략을 나타내지 않는 경우, 이 서브태스크에 대해서 당신은 0ドル$점을 얻는다.

서브태스크 3은 부분 점수가 있다. 이 서브태스크에 대해서 리턴한 모든 배열에서 $x$ 값의 최대가 $m$이라고 하자. 이 서브태스크에서 당신의 점수는 다음 표와 같다.

조건 점수
40ドル \le m \le 60$ 20ドル$
26ドル \le m \le 39$ 25ドル + 1.5 \times (40 - m)$
$m = 25$ 50ドル$
$m = 24$ 55ドル$
$m = 23$ 62ドル$
$m = 22$ 70ドル$
$m = 21$ 80ドル$
$m \le 20$ 90ドル$

힌트

[{"problem_id":"25439","problem_lang":"0","title":"\uc8c4\uc218\ub4e4\uc758 \ub3c4\uc804","description":"<p>\uac10\uc625\uc5d0 $500$\uba85\uc758 \uc8c4\uc218\uac00 \uac07\ud600 \uc788\ub2e4. \uc5b4\ub290\ub0a0, \uac04\uc218\ub294 \uac10\uc625\uc5d0\uc11c \ub098\uac08 \uc218 \uc788\ub294 \uae30\ud68c\ub97c \uc8fc\uc5c8\ub2e4. \uac04\uc218\uac00 \ubc29 \uc548\uc5d0 \ub3d9\uc804\uc774 \ub4e0 \ub450 \uac1c\uc758 \uac00\ubc29 A\uc640 B\ub97c \ub193\uc558\ub2e4. \uac01 \uac00\ubc29\uc5d0\ub294 $1$ \uac1c \uc774\uc0c1 $N$ \uac1c \uc774\ud558\uc758 \ub3d9\uc804\uc774 \ub4e4\uc5b4 \uc788\ub2e4. \ub450 \uac00\ubc29\uc5d0 \ub4e0 \ub3d9\uc804\uc758 \uac1c\uc218\ub294 <strong>\ub2e4\ub974\ub2e4<\/strong>. \uac04\uc218\ub294 \uc8c4\uc218\ub4e4\uc5d0\uac8c \ub3c4\uc804 \uae30\ud68c\ub97c \uc900\ub2e4. \uc8c4\uc218\ub4e4\uc758 \ubaa9\ud45c\ub294 \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc744 \ucc3e\ub294 \uac83\uc774\ub2e4.<\/p>\r\n\r\n<p>\ubc29\uc5d0\ub294 \ub3d9\uc804\uc774 \ub4e0 \uac00\ubc29 \uc678\uc5d0\ub3c4 \uce60\ud310\uc774 \uc788\ub2e4. \uce60\ud310\uc5d0\ub294 \ud56d\uc0c1 \uc815\uc218 \ud558\ub098\ub9cc \uc4f8 \uc218 \uc788\ub2e4. \ucc98\uc74c\uc5d0\ub294 \uce60\ud310\uc5d0 $0$\uc774 \uc4f0\uc5ec \uc788\ub2e4.<\/p>\r\n\r\n<p>\uac04\uc218\ub294 \uc8c4\uc218\ub4e4\uc5d0\uac8c \ud55c\uba85\uc529 \ucc28\ub840\ub85c \ubc29\uc5d0 \ub4e4\uc5b4\uc624\uac8c \ud55c\ub2e4. \ubaa8\ub4e0 \uc8c4\uc218\ub294 \ub2e4\ub978 \uc8c4\uc218\uc911 \ub204\uac00 \uc790\uae30\ubcf4\ub2e4 \uba3c\uc800 \uc774 \ubc29\uc5d0 \ub4e4\uc5b4 \uc654\ub294\uc9c0 \uc54c\uc9c0 \ubabb\ud558\uace0, \ub610 \uc790\uae30 \uc55e\uc5d0 \uba87 \uba85\uc758 \uc8c4\uc218\uac00 \ubc29\uc5d0 \ub4e4\uc5b4\uc654\ub294\uc9c0\ub3c4 \uc54c\uc9c0 \ubabb\ud55c\ub2e4. \ub9e4\ubc88 \uc8c4\uc218\uac00 \ubc29\uc5d0 \ub4e4\uc5b4\uc62c \ub54c\ub9c8\ub2e4, \uce60\ud310\uc5d0 \uc4f0\uc5ec\uc9c4 \uc815\uc218\ub97c \uc77d\ub294\ub2e4. \uc774 \uc815\uc218\ub97c \uc77d\uc740 \ub2e4\uc74c, \uac00\ubc29 A\uc640 B \uc911 \ud558\ub098\ub97c \uace8\ub77c\uc57c \ud55c\ub2e4. \ub2e4\uc74c \uc774 \uac00\ubc29\uc744 <strong>\uc870\uc0ac<\/strong>\ud574\uc11c \uc774 \uac00\ubc29\uc5d0 \uba87 \uac1c\uc758 \ub3d9\uc804\uc774 \uc788\ub294\uc9c0 \uc54c\uac8c \ub41c\ub2e4. \uadf8 \ub2e4\uc74c \uc8c4\uc218\ub294 \ub2e4\uc74c \ub450 <strong>\ud589\ub3d9<\/strong> \uc911 \ud558\ub098\ub97c \ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uce60\ud310\uc5d0 \uc4f0\uc5ec\uc9c4 \uc815\uc218\ub97c \uc9c0\uc6b0\uace0 \uc74c\uc774 \uc544\ub2cc \uc815\uc218\ub97c \uc4f4 \ub2e4\uc74c \ubc29\uc744 \ub098\uac04\ub2e4. \uce60\ud310\uc5d0 \uba3c\uc800 \uc4f0\uc5ec\uc9c4 \uc815\uc218\uc640 \uac19\uc740 \uc815\uc218\ub97c \uc4f8 \uc218\ub3c4 \uc788\uace0, \ub2e4\ub978 \uc815\uc218\ub97c \uc4f8 \uc218\ub3c4 \uc788\ub2e4. \ub3c4\uc804\uc740 \uacc4\uc18d \uc774\uc5b4\uc9c4\ub2e4. ($500$\uba85\uc758 \uc8c4\uc218 \ubaa8\ub450\uac00 \ubc29\uc744 \ub4e4\uc5b4\uc654\ub2e4\uac00 \ub098\uac04 \uacbd\uc6b0\ub97c \uc81c\uc678\ud558\uace0)<\/li>\r\n\t<li>\ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc744 \uace0\ub974\uace0 \ub3c4\uc804\uc744 \uc885\ub8cc\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ud55c\ubc88 \ubc29\uc744 \ub098\uac04 \uc8c4\uc218\ub294 \uac04\uc218\uac00 \ub2e4\uc2dc \ubc29\uc5d0 \ub4e4\uc5ec\ubcf4\ub0b4\uc9c0 \uc54a\ub294\ub2e4.<\/p>\r\n\r\n<p>\ub9cc\uc57d \uc8c4\uc218 \uc911 \ud55c \uba85\uc774 \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc744 \uc815\ud655\ud788 \ub9de\ucd94\uba74 \uc8c4\uc218\ub4e4\uc774 \ub3c4\uc804\uc5d0\uc11c \uc774\uae34\ub2e4. \ub9cc\uc57d \uc8c4\uc218 \uc911 \ud55c \uba85\uc774\ub77c\ub3c4 \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc744 \ud2c0\ub9ac\uac70\ub098, $500$\uba85\uc758 \uc8c4\uc218 \ubaa8\ub450\uac00 \ubc29\uc5d0 \ub4e4\uc5b4\uac14\ub2e4 \ub098\uc654\uc9c0\ub9cc \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc744 \ub9de\ucd94\ub824\uace0 \uc544\ubb34\ub3c4 \uc2dc\ub3c4\ud558\uc9c0 \uc54a\uc558\ub2e4\uba74 \uc8c4\uc218\ub4e4\uc774 \uc9c4\ub2e4.<\/p>\r\n\r\n<p>\ub3c4\uc804\uc744 \uc2dc\uc791\ud558\uae30 \uc804\uc5d0, \uc8c4\uc218\ub4e4\uc740 \uac15\ub2f9\uc5d0 \ubaa8\uc5ec\uc11c 3\ub2e8\uacc4\ub85c \uc774\ub8e8\uc5b4\uc9c0\ub294 \ub2e4\uc74c \uacf5\ud1b5 <strong>\uc804\ub7b5<\/strong>\uc744 \uc815\ud588\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uce60\ud310\uc5d0 \uc4f8 \uc218 \uc788\ub294 \uc74c\uc774 \uc544\ub2cc \uc815\uc218\uc758 \ucd5c\ub300\uac12 $x$\ub97c \uc815\ud55c\ub2e4.<\/li>\r\n\t<li>\ubc29\uc5d0 \ub4e4\uc5b4\uac14\uc744 \ub54c \uce60\ud310\uc5d0 \uc815\uc218 $i$\uac00 \uc4f0\uc5ec\uc838 \uc788\ub2e4\uba74 ($0 \\le i \\le x$) \uc5b4\ub290 \uac00\ubc29\uc744 \uc870\uc0ac\ud560 \uac83\uc778\uc9c0\ub97c \uc815\ud55c\ub2e4.<\/li>\r\n\t<li>\uc870\uc0ac\ud55c \uac00\ubc29\uc758 \ub3d9\uc804 \uac1c\uc218\ub97c \uc54c\uac8c \ub418\uba74 \uc5b4\ub5a4 \ud589\ub3d9\uc744 \ud560 \uac83\uc778\uc9c0\ub97c \uacb0\uc815\ud55c\ub2e4. \ubcf4\ub2e4 \uad6c\uccb4\uc801\uc73c\ub85c, \uce60\ud310\uc5d0 \uc815\uc218 $i$\uac00 \uc4f0\uc5ec\uc838 \uc788\uace0 ($0 \\le i \\le x$) \uc870\uc0ac\ud55c \uac00\ubc29\uc5d0 \ub3d9\uc804 $j$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \ub2e4\uc74c \ub450 \ud589\ub3d9 \uc911 \ud558\ub098\ub97c \ud558\ub294 \uac83\uc73c\ub85c \uacb0\uc815\ud574\uc57c \ud55c\ub2e4.\r\n\t<ul>\r\n\t\t<li>$0$ \uc774\uc0c1 $x$ \uc774\ud558\uc778 \uc5b4\ub5a4 \uc815\uc218\ub97c \uce60\ud310\uc5d0 \uc4f8 \uc9c0, \ub610\ub294<\/li>\r\n\t\t<li>\uc5b4\ub290 \uac00\ubc29\uc744 \ub3d9\uc804\uc774 \uc801\uc740 \ucabd\uc73c\ub85c \uace0\ub97c\uc9c0.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>\uc8c4\uc218\ub4e4\uc774 \ub3c4\uc804\uc5d0\uc11c \uc774\uae30\uba74, \uac04\uc218\ub294 \uc8c4\uc218\ub4e4\uc744 $x$\uc77c\uac04 \ub354 \uac00\ub454 \ub2e4\uc74c\uc5d0 \ubaa8\ub450 \ud480\uc5b4\uc904 \uac83\uc774\ub2e4.<\/p>\r\n\r\n<p>\ub2f9\uc2e0\uc774 \ud560 \uc77c\uc740 \uc8c4\uc218\ub4e4\uc774 \uc774 \ub3c4\uc804\uc744 \uc774\uae38 \uc218 \uc788\ub294 \uc804\ub7b5\uc744 \uace0\uc548\ud558\ub294 \uac83\uc774\ub2e4. (\uac00\ubc29 A, B\uc5d0 \uc788\ub294 \ub3d9\uc804 \uac1c\uc218\uc640 \ubb34\uad00\ud558\uac8c) \uc5ec\ub7ec\ubd84\uc774 \uc81c\ucd9c\ud55c \ud574\ubc95\uc758 \uc810\uc218\ub294 $x$\uc758 \uac12\uc5d0 \ub530\ub77c \ub2ec\ub77c\uc9c4\ub2e4. (\uc790\uc138\ud55c \ub0b4\uc6a9\uc740 Subtasks \ucc38\uc870)<\/p>\r\n","input":"","output":"","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$2 \\le N \\le 5000$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N \\le 500$, $x$\ub294 $500$ \uc774\ud558\uc5ec\uc57c \ud55c\ub2e4.<\/p>\r\n","subtask2":"<p>$N \\le 500$, $x$\ub294 $70$ \uc774\ud558\uc5ec\uc57c \ud55c\ub2e4.<\/p>\r\n","subtask3":"<p>$x$\ub294 $60$ \uc774\ud558\uc5ec\uc57c \ud55c\ub2e4.<\/p>\r\n","custom_implementation":"<p>\ub2e4\uc74c \ud568\uc218\ub97c \uad6c\ud604\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n<code>int[][] devise_strategy(int N)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: \uac00\ubc29 \ud558\ub098\uc5d0 \ub4e4\uc5b4\uac08 \uc218 \uc788\ub294 \ub3d9\uc804\uc758 \ucd5c\ub300 \uac1c\uc218<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 $N + 1$\uac1c\uc758 \uc815\uc218\ub97c \uc800\uc7a5\ud558\ub294 \ubc30\uc5f4\uc758 \ubc30\uc5f4 $s$\uc744 \ub9ac\ud134\ud574\uc57c \ud558\uba70, \uc774 \ubc30\uc5f4\uc774 \ub2f9\uc2e0\uc758 \uc804\ub7b5\uc744 \uc124\uba85\ud55c\ub2e4. $x$\uc758 \uac12\uc740 \ubc30\uc5f4 $s$\uc758 \uae38\uc774\uc5d0\uc11c 1\uc744 \ube80 \uac12\uc774\ub2e4. $0 \\le i \\le x$\uc778 \uac01 $i$\uc5d0 \ub300\ud574\uc11c, \ubc30\uc5f4 $s[i]$\uc740 \uc8c4\uc218\uac00 \ubc29\uc5d0 \ub4e4\uc5b4\uac14\uc744 \ub54c \uce60\ud310\uc5d0\uc11c \uc815\uc218 $i$\ub97c \uc77d\uc5c8\ub2e4\uba74 \ubb34\uc5c7\uc744 \ud574\uc57c \ud558\ub294\uc9c0\ub97c \ub098\ud0c0\ub0b8\ub2e4.\r\n\t<ol>\r\n\t\t<li>\uc8c4\uc218\uac00 \ub9cc\uc57d \uac00\ubc29 A\ub97c \uc870\uc0ac\ud574\ubd10\uc57c \ud558\uba74 $s[i][0]$\uc758 \uac12\uc740 $0$\uc774\uace0, \ub9cc\uc57d \uac00\ubc29 B\ub97c \uc870\uc0ac\ud574\ubd10\uc57c \ud558\uba74 $1$\uc774\ub2e4.<\/li>\r\n\t\t<li>$j$\uac00 \uc870\uc0ac\ud574\ubcf8 \uac00\ubc29\uc5d0 \ub4e4\uc5b4 \uc788\ub294 \ub3d9\uc804 \uac1c\uc218\ub77c\uace0 \ud558\uc790. \uadf8\ub807\ub2e4\uba74 \uc8c4\uc218\ub294 \ub2e4\uc74c \ud589\ub3d9\uc744 \ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<\/ol>\r\n\r\n\t<ul>\r\n\t\t<li>\ub9cc\uc57d $s[i][j]$\uc758 \uac12\uc774 $-1$\uc774\ub77c\uba74, \uc8c4\uc218\ub294 \uac00\ubc29 A\ub97c \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc73c\ub85c \uace0\ub978\ub2e4.<\/li>\r\n\t\t<li>\ub9cc\uc57d $s[i][j]$\uc758 \uac12\uc774 $-2$\uc774\ub77c\uba74, \uc8c4\uc218\ub294 \uac00\ubc29 B\ub97c \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc73c\ub85c \uace0\ub978\ub2e4.<\/li>\r\n\t\t<li>\ub9cc\uc57d $s[i][j]$\uc758 \uac12\uc774 \uc74c\uc774 \uc544\ub2c8\ub77c\uba74, \uc8c4\uc218\ub294 \uc774 \uc815\uc218\ub97c \uce60\ud310\uc5d0 \uc368\uc57c \ud55c\ub2e4. $s[i][j]$\uc758 \uac12\uc740 \ucd5c\ub300 $x$\ub77c\ub294\ub370 \uc8fc\uc758\ud558\ub77c.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \uc815\ud655\ud788 \ud55c \ubc88 \ud638\ucd9c\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>\ub2e4\uc74c \ud638\ucd9c\uc744 \uc0dd\uac01\ud574\ubcf4\uc790.<\/p>\r\n\r\n<pre>\r\n<code>devise_strategy(3)\r\n<\/code><\/pre>\r\n\r\n<p>$v$\uac00 \uc8c4\uc218\uac00 \ubc29\uc5d0 \ub4e4\uc5b4\uc654\uc744 \ub54c \uce60\ud310\uc5d0 \uc4f0\uc5ec\uc9c4 \uc815\uc218\ub77c\uace0 \ud558\uc790. \uc815\ub2f5\uc744 \ub0b4\ub294 \uc804\ub7b5 \uc911 \ud558\ub098\ub294 \ub2e4\uc74c\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\ub9cc\uc57d $v = 0$\uc774\ub77c\uba74 (\ucc98\uc74c \uc2dc\uc791\ud560 \ub54c\ub97c \ud3ec\ud568\ud574\uc11c), \uac00\ubc29 A\ub97c \uc870\uc0ac\ud55c\ub2e4.\r\n\t<ul>\r\n\t\t<li>\ub3d9\uc804 $1$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \uac00\ubc29 A\ub97c \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc73c\ub85c \uace0\ub978\ub2e4.<\/li>\r\n\t\t<li>\ub3d9\uc804 $3$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \uac00\ubc29 B\ub97c \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc73c\ub85c \uace0\ub978\ub2e4.<\/li>\r\n\t\t<li>\ub3d9\uc804 $2$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \uce60\ud310\uc5d0 $1$\uc744 \uc4f4\ub2e4. ($0$\uc744 \ub36e\uc5b4\uc4f4\ub2e4.)<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>\ub9cc\uc57d $v = 1$\uc774\ub77c\uba74 \uac00\ubc29 B\ub97c \uc870\uc0ac\ud55c\ub2e4.\r\n\t<ul>\r\n\t\t<li>\ub3d9\uc804 $1$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \uac00\ubc29 B\ub97c \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc73c\ub85c \uace0\ub978\ub2e4.<\/li>\r\n\t\t<li>\ub3d9\uc804 $3$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \uac00\ubc29 A\ub97c \ub3d9\uc804\uc774 \uc801\uac8c \ub4e0 \uac00\ubc29\uc73c\ub85c \uace0\ub978\ub2e4.<\/li>\r\n\t\t<li>\ub3d9\uc804 $2$\uac1c\uac00 \ub4e4\uc5b4 \uc788\ub2e4\uba74, \uce60\ud310\uc5d0 $0$\uc744 \uc4f4\ub2e4. ($1$\uc744 \ub36e\uc5b4\uc4f4\ub2e4.) \uc774 \uacbd\uc6b0\ub294 \uc808\ub300 \uc77c\uc5b4\ub098\uc9c0 \uc54a\ub294\ub2e4\ub294\ub370 \uc8fc\ubaa9\ud558\uc790. \uc65c\ub0d0\ud558\uba74 \uc774\ub54c \ub450 \uac00\ubc29 \ubaa8\ub450 \ub3d9\uc804 $2$\uac1c\uac00 \uc788\ub294\ub370, \ub450 \uac00\ubc29\uc5d0 \uac19\uc740 \uc218\uc758 \ub3d9\uc804\uc774 \ub4e4\uc5b4 \uc788\ub294 \uac83\uc744 \ud5c8\uc6a9\ud558\uc9c0 \uc54a\uae30 \ub54c\ubb38\uc774\ub2e4.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>\uc774 \uc804\ub7b5\uc744 \ud45c\ud604\ud558\ub824\uba74 \ud568\uc218\ub294 <code>[[0, -1, 1, -2], [1, -2, 0, -1]]<\/code>\ub97c \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4. \ub9ac\ud134\ub41c \ubc30\uc5f4\uc758 \uae38\uc774\ub294 $2$\uc774\uace0, $x$\uc758 \uac12\uc740 $2 - 1 = 1$\uc774\ub2e4.<\/p>\r\n","custom_subtask_scoring_a":"<p>\ub9cc\uc57d \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4 \uc911 \uc5b4\ub290 \uacbd\uc6b0\uc5d0\uc11c\ub4e0, <code>devise_strategy<\/code>\uac00 \ub9ac\ud134\ud55c \ubc30\uc5f4\uc774 \uc815\ud655\ud55c \uc804\ub7b5\uc744 \ub098\ud0c0\ub0b4\uc9c0 \uc54a\ub294 \uacbd\uc6b0, \uc774 \uc11c\ube0c\ud0dc\uc2a4\ud06c\uc5d0 \ub300\ud574\uc11c \ub2f9\uc2e0\uc740 $0$\uc810\uc744 \uc5bb\ub294\ub2e4.<\/p>\r\n\r\n<p>\uc11c\ube0c\ud0dc\uc2a4\ud06c 3\uc740 \ubd80\ubd84 \uc810\uc218\uac00 \uc788\ub2e4. \uc774 \uc11c\ube0c\ud0dc\uc2a4\ud06c\uc5d0 \ub300\ud574\uc11c \ub9ac\ud134\ud55c \ubaa8\ub4e0 \ubc30\uc5f4\uc5d0\uc11c $x$ \uac12\uc758 \ucd5c\ub300\uac00 $m$\uc774\ub77c\uace0 \ud558\uc790. \uc774 \uc11c\ube0c\ud0dc\uc2a4\ud06c\uc5d0\uc11c \ub2f9\uc2e0\uc758 \uc810\uc218\ub294 \ub2e4\uc74c \ud45c\uc640 \uac19\ub2e4.<\/p>\r\n\r\n<table class=\"table table-bordered table-center-30\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>\uc870\uac74<\/th>\r\n\t\t\t<th>\uc810\uc218<\/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>$40 \\le m \\le 60$<\/td>\r\n\t\t\t<td>$20$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$26 \\le m \\le 39$<\/td>\r\n\t\t\t<td>$25 + 1.5 \\times (40 - m)$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 25$<\/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>$m = 24$<\/td>\r\n\t\t\t<td>$55$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 23$<\/td>\r\n\t\t\t<td>$62$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 22$<\/td>\r\n\t\t\t<td>$70$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 21$<\/td>\r\n\t\t\t<td>$80$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m \\le 20$<\/td>\r\n\t\t\t<td>$90$<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n","custom_samplegrader":"<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c \uc591\uc2dd\uc73c\ub85c \uc785\ub825\uc744 \uc77d\ub294\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N$<\/li>\r\n\t<li>line $2 + k$ ($0 \\le k$): $A[k] \\, B[k]$<\/li>\r\n\t<li>last line: $-1$<\/li>\r\n<\/ul>\r\n\r\n<p>\uccab \uc904\uacfc \ub9c8\uc9c0\ub9c9 \uc904\uc744 \uc81c\uc678\ud55c \uac01\uac01\uc758 \uc904\ub4e4\uc740 \uc2dc\ub098\ub9ac\uc624\ub97c \uc124\uba85\ud55c\ub2e4. \uc2dc\ub098\ub9ac\uc624 $k$\ub294 $2+k$ \ubc88\uc9f8 \uc904\uc5d0 \uc124\uba85\ub418\uc5b4 \uc788\ub2e4. \uc2dc\ub098\ub9ac\uc624 $k$\uc5d0\uc11c\ub294 \uac00\ubc29 A\uc5d0 $A[k]$\uac1c\uc758 \ub3d9\uc804\uc774 \uc788\uace0, \uac00\ubc29 B\uc5d0 $B[k]$ \uac1c\uc758 \ub3d9\uc804\uc774 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \uba3c\uc800 <code>devise_strategy(N)<\/code>\ub97c \ud638\ucd9c\ud55c\ub2e4. $x$\uc758 \uac12\uc740 \uc774 \ud638\ucd9c\uc5d0\uc11c \ub9ac\ud134\ud55c \ubc30\uc5f4\uc758 \uae38\uc774\uc5d0\uc11c 1\uc744 \ube80 \uac12\uc774\ub2e4. \uc774\ub54c, \uc0d8\ud50c \uadf8\ub808\uc774\ub354\uac00 <code>devise_strategy<\/code>\uac00 \ub9ac\ud134\ud55c \ubc30\uc5f4\uc774 Implementation Details\uc5d0\uc11c \uc124\uba85\ud55c \uc81c\uc57d \uc870\uac74\uc744 \ub530\ub974\uc9c0 \uc54a\ub294\ub2e4\uba74, \ub2e4\uc74c \uc5d0\ub7ec \uba54\uc2dc\uc9c0 \uc911 \ud558\ub098\ub97c \ucd9c\ub825\ud558\uace0 \uc885\ub8cc\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li><code>s is an empty array<\/code>: $s$\uac00 \uae38\uc774\uac00 0\uc778 \ubc30\uc5f4\uc774\ub2e4. (\ud0c0\ub2f9\ud55c \uc804\ub7b5\uc744 \ud45c\ud604\ud558\uc9c0 \uc54a\ub294\ub2e4)<\/li>\r\n\t<li><code>s[i] contains incorrect length<\/code>: $s[i]$\uc758 \uae38\uc774\uac00 $N + 1$\uac00 \uc544\ub2cc \uc778\ub371\uc2a4 $i$ ($0 \\le i \\le x$)\uac00 \uc788\ub2e4.<\/li>\r\n\t<li><code>First element of s[i] is non-binary<\/code>: $s[i][0]$\uc758 \uac12\uc774 $0$ \ub610\ub294 $1$\uac00 \uc544\ub2cc \uc778\ub371\uc2a4 $i$ ($0 \\le i \\le x$)\uac00 \uc788\ub2e4.<\/li>\r\n\t<li><code>s[i][j] contains incorrect value<\/code>: $s[i][j]$\uc758 \uac12\uc774 $-2$ \uc774\uc0c1 $x$ \uc774\ud558\uac00 \uc544\ub2cc \uc778\ub371\uc2a4 $i, j$ ($0 \\le i \\le x, 1 \\le j \\le N$)\uac00 \uc788\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uadf8\ub807\uc9c0 \uc54a\ub2e4\uba74, \uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub450 \uac00\uc9c0 \ucd9c\ub825\uc744 \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uba3c\uc800, \uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c \uc591\uc2dd\uc73c\ub85c \uc5ec\ub7ec\ubd84\uc758 \uc804\ub7b5\uc758 \uacb0\uacfc\ub97c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + k$ ($0 \\le k$): \uc2dc\ub098\ub9ac\uc624 $k$\uc5d0 \ub300\ud55c \uc5ec\ub7ec\ubd84\uc758 \uc804\ub7b5\uc758 \uacb0\uacfc. \ub9cc\uc57d \uc774 \uc804\ub7b5\uc744 \uc368\uc11c \uc8c4\uc218\uac00 \uac00\ubc29 A\ub97c \ub3d9\uc804\uc774 \uc801\uc740 \ucabd\uc73c\ub85c \uace8\ub790\ub2e4\uba74, \ucd9c\ub825\uc740 \uae00\uc790 <code>A<\/code>\uc774\ub2e4. \ub9cc\uc57d \uc774 \uc804\ub7b5\uc744 \uc368\uc11c \uc8c4\uc218\uac00 \uac00\ubc29 B\ub97c \ub3d9\uc804\uc774 \uc801\uc740 \ucabd\uc73c\ub85c \uace8\ub790\ub2e4\uba74, \ucd9c\ub825\uc740 \uae00\uc790 <code>B<\/code>\uc774\ub2e4. \ub9cc\uc57d \uc774 \uc804\ub7b5\uc744 \uc37c\ub294\ub370 \uc5b4\ub290 \uc8c4\uc218\ub3c4 \ub3d9\uc804\uc774 \uc801\uc740 \ucabd \uac00\ubc29\uc744 \uace0\ub974\uc9c0 \ubabb\ud588\ub2e4\uba74, \ucd9c\ub825\uc740 \uae00\uc790 <code>X<\/code>\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ub610\ud55c, \uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ud604\uc7ac \ub514\ub809\ud1a0\ub9ac\uc5d0 <code>log.txt<\/code> \ud30c\uc77c\uc744 \ub2e4\uc74c \uc591\uc2dd\uc73c\ub85c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + k$ ($0 \\le k$): $w[k][0] \\, w[k][1] \\, \\ldots$<\/li>\r\n<\/ul>\r\n\r\n<p>$1 + k$\ubc88\uc9f8 \uc904\uc5d0 \ucd9c\ub825\ub41c \uc218\uc5f4\uc740 \uc2dc\ub098\ub9ac\uc624 $k$\uc5d0\uc11c \uce60\ud310\uc5d0 \uc4f0\uc5ec\uc9c0\ub294 \uc815\uc218\ub4e4\uc774\ub2e4. \ubcf4\ub2e4 \uad6c\uccb4\uc801\uc73c\ub85c, $w[k][l]$\ub294 \ubc29\uc5d0 $l+1$ \ubc88\uc9f8 \ub4e4\uc5b4\uac04 \uc8c4\uc218\uac00 \uce60\ud310\uc5d0 \uc4f0\ub294 \uc815\uc218\uc774\ub2e4.<\/p>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/fa8fd628-2795-47ac-9ced-c6a04c0a7fd2\/\">prison.zip<\/a><\/li>\r\n<\/ul>\r\n"},{"problem_id":"25439","problem_lang":"1","title":"Prisoner Challenge","description":"<p>In a prison, there are $500$ prisoners. One day, the warden offers them a chance to free themselves. He places two bags with money, bag A and bag B, in a room. Each bag contains between $1$ and $N$ coins, inclusive. The number of coins in bag A is&nbsp;<strong>different<\/strong>&nbsp;from the number of coins in bag B. The warden presents the prisoners with a challenge. The goal of the prisoners is to identify the bag with fewer coins.<\/p>\r\n\r\n<p>The room, in addition to the money bags, also contains a whiteboard. A single number must be written on the whiteboard at any time. Initially, the number on the whiteboard is $0$.<\/p>\r\n\r\n<p>Then, the warden asks the prisoners to enter the room, one by one. The prisoner who enters the room does not know which or how many other prisoners have entered the room before them. Every time a prisoner enters the room, they read the number currently written on the whiteboard. After reading the number, they must choose either bag A or bag B. The prisoner then&nbsp;<strong>inspects<\/strong>&nbsp;the chosen bag, thus getting to know the number of coins inside it. Then, the prisoner must perform either of the following two&nbsp;<strong>actions<\/strong>:<\/p>\r\n\r\n<ul>\r\n\t<li>Overwrite the number on the whiteboard with a non-negative integer and leave the room. Note that they can either change or keep the current number. The challenge continues after that (unless all $500$ prisoners have already entered the room).<\/li>\r\n\t<li>Identify one bag as the one that has fewer coins. This immediately ends the challenge.<\/li>\r\n<\/ul>\r\n\r\n<p>The warden will not ask a prisoner who has left the room to enter the room again.<\/p>\r\n\r\n<p>The prisoners win the challenge if one of them correctly identifies the bag with fewer coins. They lose if any of them identifies the bag incorrectly, or all $500$ of them have entered the room and not attempted to identify the bag with fewer coins.<\/p>\r\n\r\n<p>Before the challenge starts, the prisoners gather in the prison hall and decide on a common&nbsp;<strong>strategy<\/strong>&nbsp;for the challenge in three steps.<\/p>\r\n\r\n<ul>\r\n\t<li>They pick a non-negative integer $x$, which is the largest number they may ever want to write on the whiteboard.<\/li>\r\n\t<li>They decide, for any number $i$ written on the whiteboard ($0 \\le i \\le x$), which bag should be inspected by a prisoner who reads number $i$ from the whiteboard upon entering the room.<\/li>\r\n\t<li>They decide what action a prisoner in the room should perform after getting to know the number of coins in the chosen bag. Specifically, for any number $i$ written on the whiteboard ($0 \\le i \\le x$) and any number of coins $j$ seen in the inspected bag ($1 \\le j \\le N$), they either decide\r\n\t<ul>\r\n\t\t<li>what number between $0$ and $x$ (inclusive) should be written on the whiteboard, or<\/li>\r\n\t\t<li>which bag should be identified as the one with fewer coins.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>Upon winning the challenge, the warden will release the prisoners after serving $x$ more days.<\/p>\r\n\r\n<p>Your task is to devise a strategy for the prisoners that would ensure they win the challenge (regardless of the number of coins in bag A and bag B). The score of your solution depends on the value of $x$ (see Subtasks section for details).<\/p>\r\n","input":"","output":"","hint":"","original":"1","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$2 \\le N \\le 5000$<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N \\le 500$, the value of $x$ must not be more than $500$.<\/p>\r\n","subtask2":"<p>$N \\le 500$, the value of $x$ must not be more than $70$.<\/p>\r\n","subtask3":"<p>The value of $x$ must not be more than $60$.<\/p>\r\n","custom_implementation":"<p>You should implement the following procedure:<\/p>\r\n\r\n<pre>\r\n<code>int[][] devise_strategy(int N)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: the maximum possible number of coins in each bag.<\/li>\r\n\t<li>This procedure should return an array $s$ of arrays of $N + 1$ integers, representing your strategy. The value of $x$ is the length of array $s$ minus one. For each $i$ such that $0 \\le i \\le x$, the array $s[i]$ represents what a prisoner should do if they read number $i$ from the whiteboard upon entering the room:\r\n\t<ol>\r\n\t\t<li>The value of $s[i][0]$ is $0$ if the prisoner should inspect bag A, or $1$ if the prisoner should inspect bag B.<\/li>\r\n\t\t<li>Let $j$ be the number of coins seen in the chosen bag. The prisoner should then perform the following action:<\/li>\r\n\t<\/ol>\r\n\r\n\t<ul>\r\n\t\t<li>If the value of $s[i][j]$ is $-1$, the prisoner should identify bag A as the one with fewer coins.<\/li>\r\n\t\t<li>If the value of $s[i][j]$ is $-2$, the prisoner should identify bag B as the one with fewer coins.<\/li>\r\n\t\t<li>If the value of $s[i][j]$ is a non-negative number, the prisoner should write that number on the whiteboard. Note that $s[i][j]$ must be at most $x$.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>This procedure is called exactly once.<\/li>\r\n<\/ul>\r\n","custom_example":"<p>Consider the following call:<\/p>\r\n\r\n<pre>\r\n<code>devise_strategy(3)\r\n<\/code><\/pre>\r\n\r\n<p>Let $v$ denote the number the prisoner reads from the whiteboard upon entering the room. One of the correct strategies is as follows:<\/p>\r\n\r\n<ul>\r\n\t<li>If $v = 0$ (including the initial number), inspect bag A.\r\n\t<ul>\r\n\t\t<li>If it contains $1$ coin, identify bag A as the one with fewer coins.<\/li>\r\n\t\t<li>If it contains $3$ coins, identify bag B as the one with fewer coins.<\/li>\r\n\t\t<li>If it contains $2$ coins, write $1$ on the whiteboard (overwriting $0$).<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>If $v = 1$, inspect bag B.\r\n\t<ul>\r\n\t\t<li>If it contains $1$ coin, identify bag B as the one with fewer coins.<\/li>\r\n\t\t<li>If it contains $3$ coins, identify bag A as the one with fewer coins.<\/li>\r\n\t\t<li>If it contains $2$ coins, write $0$ on the whiteboard (overwriting $1$). Note that this case can never happen, as we can conclude that both bags contain $2$ coins, which is not allowed.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>To report this strategy the procedure should return <code>[[0, -1, 1, -2], [1, -2, 0, -1]]<\/code>. The length of the returned array is $2$, so for this return value the value of $x$ is $2 - 1 = 1$.<\/p>\r\n","custom_subtask_scoring_a":"<p>If in any of the test cases, the array returned by <code>devise_strategy<\/code> does not represent a correct strategy, the score of your solution for that subtask will be $0$.<\/p>\r\n\r\n<p>In subtask 3 you can obtain a partial score. Let $m$ be the maximum value of $x$ for the returned arrays over all test cases in this subtask. Your score for this subtask is calculated according to the following table:<\/p>\r\n\r\n<table class=\"table table-bordered table-center-30\">\r\n\t<thead>\r\n\t\t<tr>\r\n\t\t\t<th>Condition<\/th>\r\n\t\t\t<th>Points<\/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>$40 \\le m \\le 60$<\/td>\r\n\t\t\t<td>$20$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$26 \\le m \\le 39$<\/td>\r\n\t\t\t<td>$25 + 1.5 \\times (40 - m)$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 25$<\/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>$m = 24$<\/td>\r\n\t\t\t<td>$55$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 23$<\/td>\r\n\t\t\t<td>$62$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 22$<\/td>\r\n\t\t\t<td>$70$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m = 21$<\/td>\r\n\t\t\t<td>$80$<\/td>\r\n\t\t<\/tr>\r\n\t\t<tr>\r\n\t\t\t<td>$m \\le 20$<\/td>\r\n\t\t\t<td>$90$<\/td>\r\n\t\t<\/tr>\r\n\t<\/tbody>\r\n<\/table>\r\n","custom_samplegrader":"<p>The sample grader reads the input in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N$<\/li>\r\n\t<li>line $2 + k$ ($0 \\le k$): $A[k] \\, B[k]$<\/li>\r\n\t<li>last line: $-1$<\/li>\r\n<\/ul>\r\n\r\n<p>Each line except the first and the last one represents a scenario. We refer to the scenario described in line $2 + k$ as scenario $k$. In scenario $k$ bag A contains $A[k]$ coins and bag B contains $B[k]$ coins.<\/p>\r\n\r\n<p>The sample grader first calls <code>devise_strategy(N)<\/code>. The value of $x$ is the length of the array returned by the call minus one. Then, if the sample grader detects that the array returned by <code>devise_strategy<\/code> does not conform to the constraints described in Implementation Details, it prints one of the following error messages and exits:<\/p>\r\n\r\n<ul>\r\n\t<li><code>s is an empty array<\/code>: $s$ is an empty array (which does not represent a valid strategy).<\/li>\r\n\t<li><code>s[i] contains incorrect length<\/code>: There exists an index $i$ ($0 \\le i \\le x$) such that the length of $s[i]$ is not $N + 1$.<\/li>\r\n\t<li><code>First element of s[i] is non-binary<\/code>: There exists an index $i$ ($0 \\le i \\le x$) such that $s[i][0]$ is neither $0$ nor $1$.<\/li>\r\n\t<li><code>s[i][j] contains incorrect value<\/code>: There exist indices $i, j$ ($0 \\le i \\le x, 1 \\le j \\le N$) such that $s[i][j]$ is not between $-2$ and $x$.<\/li>\r\n<\/ul>\r\n\r\n<p>Otherwise, the sample grader produces two outputs.<\/p>\r\n\r\n<p>First, the sample grader prints the output of your strategy in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + k$ ($0 \\le k$): output of your strategy for scenario $k$. If applying the strategy leads to a prisoner identifying bag A as the one with fewer coins, then the output is the character <code>A<\/code>. If applying the strategy leads to a prisoner identifying bag B as the one with fewer coins, then the output is the character <code>B<\/code>. If applying the strategy does not lead to any prisoner identifying a bag with fewer coins, then the output is the character <code>X<\/code>.<\/li>\r\n<\/ul>\r\n\r\n<p>Second, the sample grader writes a file <code>log.txt<\/code> in the current directory in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1 + k$ ($0 \\le k$): $w[k][0] \\, w[k][1] \\, \\ldots$<\/li>\r\n<\/ul>\r\n\r\n<p>The sequence on line $1 + k$ corresponds to scenario $k$ and describes the numbers written on the whiteboard. Specifically, $w[k][l]$ is the number written by the ${(l+1)}^{th}$ prisoner to enter the room.<\/p>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/fa8fd628-2795-47ac-9ced-c6a04c0a7fd2\/\">prison.zip<\/a><\/li>\r\n<\/ul>\r\n"}]

샘플 그레이더

샘플 그레이더는 다음 양식으로 입력을 읽는다.

  • line 1ドル$: $N$
  • line 2ドル + k$ (0ドル \le k$): $A[k] ,円 B[k]$
  • last line: $-1$

첫 줄과 마지막 줄을 제외한 각각의 줄들은 시나리오를 설명한다. 시나리오 $k$는 2ドル+k$ 번째 줄에 설명되어 있다. 시나리오 $k$에서는 가방 A에 $A[k]$개의 동전이 있고, 가방 B에 $B[k]$ 개의 동전이 있다.

샘플 그레이더는 먼저 devise_strategy(N)를 호출한다. $x$의 값은 이 호출에서 리턴한 배열의 길이에서 1을 뺀 값이다. 이때, 샘플 그레이더가 devise_strategy가 리턴한 배열이 Implementation Details에서 설명한 제약 조건을 따르지 않는다면, 다음 에러 메시지 중 하나를 출력하고 종료한다.

  • s is an empty array: $s$가 길이가 0인 배열이다. (타당한 전략을 표현하지 않는다)
  • s[i] contains incorrect length: $s[i]$의 길이가 $N + 1$가 아닌 인덱스 $i$ (0ドル \le i \le x$)가 있다.
  • First element of s[i] is non-binary: $s[i][0]$의 값이 0ドル$ 또는 1ドル$가 아닌 인덱스 $i$ (0ドル \le i \le x$)가 있다.
  • s[i][j] contains incorrect value: $s[i][j]$의 값이 $-2$ 이상 $x$ 이하가 아닌 인덱스 $i, j$ (0ドル \le i \le x, 1 \le j \le N$)가 있다.

그렇지 않다면, 샘플 그레이더는 두 가지 출력을 한다.

먼저, 샘플 그레이더는 다음 양식으로 여러분의 전략의 결과를 출력한다.

  • line 1ドル + k$ (0ドル \le k$): 시나리오 $k$에 대한 여러분의 전략의 결과. 만약 이 전략을 써서 죄수가 가방 A를 동전이 적은 쪽으로 골랐다면, 출력은 글자 A이다. 만약 이 전략을 써서 죄수가 가방 B를 동전이 적은 쪽으로 골랐다면, 출력은 글자 B이다. 만약 이 전략을 썼는데 어느 죄수도 동전이 적은 쪽 가방을 고르지 못했다면, 출력은 글자 X이다.

또한, 샘플 그레이더는 현재 디렉토리에 log.txt 파일을 다음 양식으로 출력한다.

  • line 1ドル + k$ (0ドル \le k$): $w[k][0] ,円 w[k][1] ,円 \ldots$

1ドル + k$번째 줄에 출력된 수열은 시나리오 $k$에서 칠판에 쓰여지는 정수들이다. 보다 구체적으로, $w[k][l]$는 방에 $l+1$ 번째 들어간 죄수가 칠판에 쓰는 정수이다.

첨부

출처

Olympiad > International Olympiad in Informatics > IOI 2022 > Day 1 2번

  • 문제를 만든 사람: Hirotaka Yoneda, Masataka Yoneda

제출할 수 있는 언어

C++17, C++20, C++17 (Clang), C++20 (Clang)

채점 및 기타 정보

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

출처

대학교 대회

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

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