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

25443번 - 수천개의 섬 서브태스크점수다국어언어 제한함수 구현

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

문제

수천개의 섬은 자바 해역에 위치한 아름다운 섬들의 그룹이다. 수천개의 섬은 $N$개의 섬으로 구성되며 0ドル$부터 $N - 1$까지 번호가 붙어 있다.

섬들 사이를 오가는데 사용될 수 있는 카누가 $M$개 있고 0ドル$부터 $M - 1$까지 번호가 붙어 있다. 0ドル \le i \le M - 1$인 각 $i$에 대해, $i$번 카누는 섬 $U[i]$나 섬 $V[i]$에 정박해 있거나 $U[i]$와 $V[i]$ 사이를 운항 중일 수 있다. 특별히, 카누가 섬 $U[i]$에 정박해 있을 때에는 섬 $U[i]$에서 섬 $V[i]$로 운항할 수 있고 이후 섬 $V[i]$에 정박하게 된다. 비슷하게, 카누가 섬 $V[i]$에 정박해 있을 때에는 섬 $V[i]$에서 섬 $U[i]$로 운항할 수 있고 이후 섬 $U[i]$에 정박하게 된다. 처음에 카누는 섬 $U[i]$에 정박해 있다. 여러 카누가 동일한 두 섬 사이를 오가는 것도 가능하다. 한 섬에 여러 카누가 정박하는 것도 가능하다.

안전상의 이유로 카누는 매 운항 이후 유지보수가 필요하고, 이로 인해 같은 카누가 두 번 연속해서 운항하는 것을 금지한다. 즉, $i$번 카누가 사용된 후에는, $i$번 카누가 다시 사용되기 전에 다른 카누가 반드시 사용되어야 한다.

부 뎅클렉은 몇 개의 섬을 여행할 계획을 세우려고 한다. 그녀의 여행이 유효하다는 것은 다음 조건들이 만족됨을 의미한다.

  • 그녀의 여행은 섬 0ドル$에서 시작해서 섬 0ドル$에서 끝난다.
  • 그녀는 섬 0ドル$이 아닌 다른 섬을 최소한 하나는 방문한다.
  • 여행이 끝나면, 각 카누는 여행이 시작되기 전과 동일한 섬에 정박하게 된다. 즉, 0ドル \le i \le M - 1$인 각 $i$에 대해, $i$번 카누는 섬 $U[i]$에 정박해야만 한다.

당신은 부 뎅클렉이 최대 2ドル,000円,000円$번 운항하는 유효한 여행을 찾도록 도와주거나, 그러한 유효한 여행이 없음을 결정하도록 도와야 한다. 이 문제에서 제시하는 제약조건(Constraints 부분 참고) 하에서는, 만약 유효한 여행이 존재한다면 운항 횟수가 2ドル,000円,000円$번을 넘지 않는 유효한 여행이 존재함을 증명할 수 있다.

구현

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

union(bool, int[]) find_journey(int N, int M, int[] U, int[] V)
  • $N$: 섬의 개수.
  • $M$: 카누의 개수.
  • $U,ドル $V$: 카누를 나타내는 길이 $M$인 배열.
  • 이 함수는 boolean 또는 정수 배열을 리턴해야 한다.
    • 유효한 여행이 존재하지 않는다면 false를 리턴한다.
    • 유효한 여행이 존재한다면, 두 가지 옵션이 있다:
      • 만점을 받기 위해서는, 유효한 여행을 나타내는 최대 2ドル,000円,000円$개의 정수값을 갖는 배열을 리턴해야 한다. 더 정확히는, 이 배열의 원소들은 여행에 사용되는 카누들의 번호(사용되는 순서대로)여야 한다.
      • 부분 점수를 받기 위해서는, true를 리턴하거나, 2ドル,000円,000円$개보다 많은 정수값을 갖는 배열을 리턴하거나, 또는 유효한 여행을 나타내지 않는 정수 배열을 리턴해야 한다(더 자세한 내용은 Subtasks 부분 참고).
  • 이 함수는 정확히 한번만 호출된다.

예제 1

다음 호출을 생각해보자:

find_journey(4, 5, [0, 1, 2, 0, 3], [1, 2, 3, 3, 1])

섬들과 카누들은 아래 그림과 같다.

유효한 여행으로 가능한 한가지는 다음과 같다. 부 뎅클렉은 처음에 0ドル,ドル 1ドル,ドル 2ドル,ドル 4ドル$번 카누를 순서대로 운항한다. 그 결과, 그녀는 섬 1ドル$에 있게 된다. 그 다음, 현재 섬 1ドル$에 정박해 있고 마지막에 사용한 카누가 아닌 0ドル$번 카누를 부 뎅클렉은 운항할 수 있다. 0ドル$번 카누를 다시 운항하면, 부 뎅클렉은 이제 섬 0ドル$에 있게 된다. 하지만 1ドル,ドル 2ドル,ドル 4ドル$번 카누가 여행 이전과 같은 섬에 정박해 있지 않다. 부 뎅클렉은 여행을 계속 이어서 3ドル,ドル 2ドル,ドル 1ドル,ドル 4ドル,ドル 3ドル$번 카누를 운항한다. 부 뎅클렉은 섬 0ドル$으로 돌아오고 모든 카누들도 여행 전과 동일한 섬에 정박해 있다.

따라서, 리턴 값 $[0, 1, 2, 4, 0, 3, 2, 1, 4, 3]$은 유효한 여행을 나타낸다.

예제 2

다음 호출을 생각해보자:

find_journey(2, 3, [0, 1, 1], [1, 0, 0])

섬들과 카누들은 아래 그림과 같다.

부 뎅클렉은 0ドル$번 카누를 운항해야만 하고, 그 다음 그녀는 1ドル$ 또는 2ドル$번 카누를 운항할 수 있다. 참고로 그녀는 0ドル$번 카누를 연속해서 운항할 수 없다. 어느 경우던지 부 뎅클렉은 섬 0ドル$으로 돌아간다. 하지만, 카누들은 여행 전과 같은 섬에 정박해 있지 않고, 섬 0ドル$에 정박한 유일한 카누는 방금 그녀가 사용한 카누라서 부 뎅클렉은 더 이상 운항할 수 있는 카누가 없다. 유효한 여행이 없으므로, 이 함수는 false를 리턴해야 한다.

입력

출력

제한

  • 2ドル \le N \le 100,000円$
  • 1ドル \le M \le 200,000円$
  • 0ドル \le U[i] \le N - 1$이며 0ドル \le V[i] \le N - 1$ (모든 0ドル \le i \le M - 1$)
  • $U[i] \neq V[i]$ (모든 0ドル \le i \le M - 1$)

서브태스크

번호배점제한
15

$N = 2$

25

$N \le 400$. 서로 다른 두 섬 $x$와 $y$ (0ドル \le x \lt y \le N - 1$)로 이뤄지는 각 쌍에 대해, 두 섬 사이를 운항하는데 사용될 수 있는 카누는 정확히 두 개이다. 둘 중 하나는 섬 $x$에 정박해 있고 다른 하나는 섬 $y$에 정박해 있다.

321

$N \le 1000,ドル $M$은 짝수이고, 0ドル \le i \le M - 1$인 각 짝수 $i$에 대해 $i$번과 $i + 1$번 카누는 둘 다 섬 $U[i]$와 섬 $V[i]$ 사이를 운항하는데 사용될 수 있다. $i$번 카누는 처음에 섬 $U[i]$에 정박해 있고 $i + 1$번 카누는 처음에 섬 $V[i]$에 정박해 있다. 명확히 말해, $U[i] = V[i + 1]$이고 $V[i] = U[i + 1]$이다.

424

$N \le 1000,ドル $M$은 짝수이고, 0ドル \le i \le M - 1$인 각 짝수 $i$에 대해 $i$번과 $i + 1$번 카누는 둘 다 섬 $U[i]$와 섬 $V[i]$ 사이를 운항하는데 사용될 수 있다. 두 카누 모두 처음에 섬 $U[i]$에 정박해 있다. 명확히 말해, $U[i] = U[i + 1]$이고 $V[i] = V[i + 1]$이다.

545

추가적인 제한이 없다.

유효한 여행이 존재하는 각 테스트 케이스에 대해, 당신의 답은:

  • 유효한 여행을 리턴한 경우 만점을 받고,
  • true를 리턴하거나, 2ドル,000円,000円$개보다 많은 정수값을 갖는 배열을 리턴하거나, 또는 유효한 여행을 나타내지 않는 정수 배열을 리턴한 경우 35ドル%$의 점수를 받고,
  • 그 외의 경우 0ドル$점을 받는다.

유효한 여행이 존재하지 않는 각 테스트 케이스에 대해, 당신의 답은:

  • false를 리턴한 경우 만점을 받고,
  • 그 외의 경우 0ドル$점을 받는다.

참고로, 각 서브태스크의 최종 점수는 그 서브태스크의 테스트 케이스들의 최소 점수로 정해진다.

힌트

[{"problem_id":"25443","problem_lang":"0","title":"\uc218\ucc9c\uac1c\uc758 \uc12c","description":"<p>\uc218\ucc9c\uac1c\uc758 \uc12c\uc740 \uc790\ubc14 \ud574\uc5ed\uc5d0 \uc704\uce58\ud55c \uc544\ub984\ub2e4\uc6b4 \uc12c\ub4e4\uc758 \uadf8\ub8f9\uc774\ub2e4. \uc218\ucc9c\uac1c\uc758 \uc12c\uc740 $N$\uac1c\uc758 \uc12c\uc73c\ub85c \uad6c\uc131\ub418\uba70 $0$\ubd80\ud130 $N - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uc12c\ub4e4 \uc0ac\uc774\ub97c \uc624\uac00\ub294\ub370 \uc0ac\uc6a9\ub420 \uc218 \uc788\ub294 \uce74\ub204\uac00 $M$\uac1c \uc788\uace0 $0$\ubd80\ud130 $M - 1$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\ub2e4. $0 \\le i \\le M - 1$\uc778 \uac01 $i$\uc5d0 \ub300\ud574, $i$\ubc88 \uce74\ub204\ub294 \uc12c $U[i]$\ub098 \uc12c $V[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\uac70\ub098 $U[i]$\uc640 $V[i]$ \uc0ac\uc774\ub97c \uc6b4\ud56d \uc911\uc77c \uc218 \uc788\ub2e4. \ud2b9\ubcc4\ud788, \uce74\ub204\uac00 \uc12c $U[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\uc744 \ub54c\uc5d0\ub294 \uc12c $U[i]$\uc5d0\uc11c \uc12c $V[i]$\ub85c \uc6b4\ud56d\ud560 \uc218 \uc788\uace0 \uc774\ud6c4 \uc12c $V[i]$\uc5d0 \uc815\ubc15\ud558\uac8c \ub41c\ub2e4. \ube44\uc2b7\ud558\uac8c, \uce74\ub204\uac00 \uc12c $V[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\uc744 \ub54c\uc5d0\ub294 \uc12c $V[i]$\uc5d0\uc11c \uc12c $U[i]$\ub85c \uc6b4\ud56d\ud560 \uc218 \uc788\uace0 \uc774\ud6c4 \uc12c $U[i]$\uc5d0 \uc815\ubc15\ud558\uac8c \ub41c\ub2e4. \ucc98\uc74c\uc5d0 \uce74\ub204\ub294 \uc12c $U[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\ub2e4. \uc5ec\ub7ec \uce74\ub204\uac00 \ub3d9\uc77c\ud55c \ub450 \uc12c \uc0ac\uc774\ub97c \uc624\uac00\ub294 \uac83\ub3c4 \uac00\ub2a5\ud558\ub2e4. \ud55c \uc12c\uc5d0 \uc5ec\ub7ec \uce74\ub204\uac00 \uc815\ubc15\ud558\ub294 \uac83\ub3c4 \uac00\ub2a5\ud558\ub2e4.<\/p>\r\n\r\n<p>\uc548\uc804\uc0c1\uc758 \uc774\uc720\ub85c \uce74\ub204\ub294 \ub9e4 \uc6b4\ud56d \uc774\ud6c4 \uc720\uc9c0\ubcf4\uc218\uac00 \ud544\uc694\ud558\uace0, \uc774\ub85c \uc778\ud574 \uac19\uc740 \uce74\ub204\uac00 \ub450 \ubc88 \uc5f0\uc18d\ud574\uc11c \uc6b4\ud56d\ud558\ub294 \uac83\uc744 \uae08\uc9c0\ud55c\ub2e4. \uc989, $i$\ubc88 \uce74\ub204\uac00 \uc0ac\uc6a9\ub41c \ud6c4\uc5d0\ub294, $i$\ubc88 \uce74\ub204\uac00 \ub2e4\uc2dc \uc0ac\uc6a9\ub418\uae30 \uc804\uc5d0 \ub2e4\ub978 \uce74\ub204\uac00 \ubc18\ub4dc\uc2dc \uc0ac\uc6a9\ub418\uc5b4\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ubd80 \ub385\ud074\ub809\uc740 \uba87 \uac1c\uc758 \uc12c\uc744 \uc5ec\ud589\ud560 \uacc4\ud68d\uc744 \uc138\uc6b0\ub824\uace0 \ud55c\ub2e4. \uadf8\ub140\uc758 \uc5ec\ud589\uc774 <strong>\uc720\ud6a8<\/strong>\ud558\ub2e4\ub294 \uac83\uc740 \ub2e4\uc74c \uc870\uac74\ub4e4\uc774 \ub9cc\uc871\ub428\uc744 \uc758\ubbf8\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uadf8\ub140\uc758 \uc5ec\ud589\uc740 \uc12c $0$\uc5d0\uc11c \uc2dc\uc791\ud574\uc11c \uc12c $0$\uc5d0\uc11c \ub05d\ub09c\ub2e4.<\/li>\r\n\t<li>\uadf8\ub140\ub294 \uc12c $0$\uc774 \uc544\ub2cc \ub2e4\ub978 \uc12c\uc744 \ucd5c\uc18c\ud55c \ud558\ub098\ub294 \ubc29\ubb38\ud55c\ub2e4.<\/li>\r\n\t<li>\uc5ec\ud589\uc774 \ub05d\ub098\uba74, \uac01 \uce74\ub204\ub294 \uc5ec\ud589\uc774 \uc2dc\uc791\ub418\uae30 \uc804\uacfc \ub3d9\uc77c\ud55c \uc12c\uc5d0 \uc815\ubc15\ud558\uac8c \ub41c\ub2e4. \uc989, $0 \\le i \\le M - 1$\uc778 \uac01 $i$\uc5d0 \ub300\ud574, $i$\ubc88 \uce74\ub204\ub294 \uc12c $U[i]$\uc5d0 \uc815\ubc15\ud574\uc57c\ub9cc \ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ub2f9\uc2e0\uc740 \ubd80 \ub385\ud074\ub809\uc774 \ucd5c\ub300 $2\\,000\\,000$\ubc88 \uc6b4\ud56d\ud558\ub294 \uc720\ud6a8\ud55c \uc5ec\ud589\uc744 \ucc3e\ub3c4\ub85d \ub3c4\uc640\uc8fc\uac70\ub098, \uadf8\ub7ec\ud55c \uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc5c6\uc74c\uc744 \uacb0\uc815\ud558\ub3c4\ub85d \ub3c4\uc640\uc57c \ud55c\ub2e4. \uc774 \ubb38\uc81c\uc5d0\uc11c \uc81c\uc2dc\ud558\ub294 \uc81c\uc57d\uc870\uac74(Constraints \ubd80\ubd84 \ucc38\uace0) \ud558\uc5d0\uc11c\ub294, \ub9cc\uc57d \uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc874\uc7ac\ud55c\ub2e4\uba74 \uc6b4\ud56d \ud69f\uc218\uac00 $2\\,000\\,000$\ubc88\uc744 \ub118\uc9c0 \uc54a\ub294 \uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc874\uc7ac\ud568\uc744 \uc99d\uba85\ud560 \uc218 \uc788\ub2e4.<\/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 100\\,000$<\/li>\r\n\t<li>$1 \\le M \\le 200\\,000$<\/li>\r\n\t<li>$0 \\le U[i] \\le N - 1$\uc774\uba70 $0 \\le V[i] \\le N - 1$ (\ubaa8\ub4e0 $0 \\le i \\le M - 1$)<\/li>\r\n\t<li>$U[i] \\neq V[i]$ (\ubaa8\ub4e0 $0 \\le i \\le M - 1$)<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N = 2$<\/p>\r\n","subtask2":"<p>$N \\le 400$. \uc11c\ub85c \ub2e4\ub978 \ub450 \uc12c $x$\uc640 $y$ ($0 \\le x \\lt y \\le N - 1$)\ub85c \uc774\ub904\uc9c0\ub294 \uac01 \uc30d\uc5d0 \ub300\ud574, \ub450 \uc12c \uc0ac\uc774\ub97c \uc6b4\ud56d\ud558\ub294\ub370 \uc0ac\uc6a9\ub420 \uc218 \uc788\ub294 \uce74\ub204\ub294 \uc815\ud655\ud788 \ub450 \uac1c\uc774\ub2e4. \ub458 \uc911 \ud558\ub098\ub294 \uc12c $x$\uc5d0 \uc815\ubc15\ud574 \uc788\uace0 \ub2e4\ub978 \ud558\ub098\ub294 \uc12c $y$\uc5d0 \uc815\ubc15\ud574 \uc788\ub2e4.<\/p>\r\n","subtask3":"<p>$N \\le 1000$, $M$\uc740 \uc9dd\uc218\uc774\uace0, $0 \\le i \\le M - 1$\uc778 \uac01 <strong>\uc9dd\uc218<\/strong> $i$\uc5d0 \ub300\ud574 $i$\ubc88\uacfc $i + 1$\ubc88 \uce74\ub204\ub294 \ub458 \ub2e4 \uc12c $U[i]$\uc640 \uc12c $V[i]$ \uc0ac\uc774\ub97c \uc6b4\ud56d\ud558\ub294\ub370 \uc0ac\uc6a9\ub420 \uc218 \uc788\ub2e4. $i$\ubc88 \uce74\ub204\ub294 \ucc98\uc74c\uc5d0 \uc12c $U[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\uace0 $i + 1$\ubc88 \uce74\ub204\ub294 \ucc98\uc74c\uc5d0 \uc12c $V[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\ub2e4. \uba85\ud655\ud788 \ub9d0\ud574, $U[i] = V[i + 1]$\uc774\uace0 $V[i] = U[i + 1]$\uc774\ub2e4.<\/p>\r\n","subtask4":"<p>$N \\le 1000$, $M$\uc740 \uc9dd\uc218\uc774\uace0, $0 \\le i \\le M - 1$\uc778 \uac01 <strong>\uc9dd\uc218<\/strong> $i$\uc5d0 \ub300\ud574 $i$\ubc88\uacfc $i + 1$\ubc88 \uce74\ub204\ub294 \ub458 \ub2e4 \uc12c $U[i]$\uc640 \uc12c $V[i]$ \uc0ac\uc774\ub97c \uc6b4\ud56d\ud558\ub294\ub370 \uc0ac\uc6a9\ub420 \uc218 \uc788\ub2e4. \ub450 \uce74\ub204 \ubaa8\ub450 \ucc98\uc74c\uc5d0 \uc12c $U[i]$\uc5d0 \uc815\ubc15\ud574 \uc788\ub2e4. \uba85\ud655\ud788 \ub9d0\ud574, $U[i] = U[i + 1]$\uc774\uace0 $V[i] = V[i + 1]$\uc774\ub2e4.<\/p>\r\n","subtask5":"<p>\ucd94\uac00\uc801\uc778 \uc81c\ud55c\uc774 \uc5c6\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>union(bool, int[]) find_journey(int N, int M, int[] U, int[] V)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: \uc12c\uc758 \uac1c\uc218.<\/li>\r\n\t<li>$M$: \uce74\ub204\uc758 \uac1c\uc218.<\/li>\r\n\t<li>$U$, $V$: \uce74\ub204\ub97c \ub098\ud0c0\ub0b4\ub294 \uae38\uc774 $M$\uc778 \ubc30\uc5f4.<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 boolean \ub610\ub294 \uc815\uc218 \ubc30\uc5f4\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.\r\n\t<ul>\r\n\t\t<li>\uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc874\uc7ac\ud558\uc9c0 \uc54a\ub294\ub2e4\uba74 <code>false<\/code>\ub97c \ub9ac\ud134\ud55c\ub2e4.<\/li>\r\n\t\t<li>\uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc874\uc7ac\ud55c\ub2e4\uba74, \ub450 \uac00\uc9c0 \uc635\uc158\uc774 \uc788\ub2e4:\r\n\t\t<ul>\r\n\t\t\t<li>\ub9cc\uc810\uc744 \ubc1b\uae30 \uc704\ud574\uc11c\ub294, \uc720\ud6a8\ud55c \uc5ec\ud589\uc744 \ub098\ud0c0\ub0b4\ub294 \ucd5c\ub300 $2\\,000\\,000$\uac1c\uc758 \uc815\uc218\uac12\uc744 \uac16\ub294 \ubc30\uc5f4\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4. \ub354 \uc815\ud655\ud788\ub294, \uc774 \ubc30\uc5f4\uc758 \uc6d0\uc18c\ub4e4\uc740 \uc5ec\ud589\uc5d0 \uc0ac\uc6a9\ub418\ub294 \uce74\ub204\ub4e4\uc758 \ubc88\ud638(\uc0ac\uc6a9\ub418\ub294 \uc21c\uc11c\ub300\ub85c)\uc5ec\uc57c \ud55c\ub2e4.<\/li>\r\n\t\t\t<li>\ubd80\ubd84 \uc810\uc218\ub97c \ubc1b\uae30 \uc704\ud574\uc11c\ub294, <code>true<\/code>\ub97c \ub9ac\ud134\ud558\uac70\ub098, $2\\,000\\,000$\uac1c\ubcf4\ub2e4 \ub9ce\uc740 \uc815\uc218\uac12\uc744 \uac16\ub294 \ubc30\uc5f4\uc744 \ub9ac\ud134\ud558\uac70\ub098, \ub610\ub294 \uc720\ud6a8\ud55c \uc5ec\ud589\uc744 \ub098\ud0c0\ub0b4\uc9c0 \uc54a\ub294 \uc815\uc218 \ubc30\uc5f4\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4(\ub354 \uc790\uc138\ud55c \ub0b4\uc6a9\uc740 Subtasks \ubd80\ubd84 \ucc38\uace0).<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>\uc774 \ud568\uc218\ub294 \uc815\ud655\ud788 \ud55c\ubc88\ub9cc \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>find_journey(4, 5, [0, 1, 2, 0, 3], [1, 2, 3, 3, 1])\r\n<\/code><\/pre>\r\n\r\n<p>\uc12c\ub4e4\uacfc \uce74\ub204\ub4e4\uc740 \uc544\ub798 \uadf8\ub9bc\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/1e037aef-d9b0-47c8-8953-6678fe50909d\/-\/preview\/\" style=\"width: 227px; height: 224px;\" \/><\/p>\r\n\r\n<p>\uc720\ud6a8\ud55c \uc5ec\ud589\uc73c\ub85c \uac00\ub2a5\ud55c \ud55c\uac00\uc9c0\ub294 \ub2e4\uc74c\uacfc \uac19\ub2e4. \ubd80 \ub385\ud074\ub809\uc740 \ucc98\uc74c\uc5d0 $0$, $1$, $2$, $4$\ubc88 \uce74\ub204\ub97c \uc21c\uc11c\ub300\ub85c \uc6b4\ud56d\ud55c\ub2e4. \uadf8 \uacb0\uacfc, \uadf8\ub140\ub294 \uc12c $1$\uc5d0 \uc788\uac8c \ub41c\ub2e4. \uadf8 \ub2e4\uc74c, \ud604\uc7ac \uc12c $1$\uc5d0 \uc815\ubc15\ud574 \uc788\uace0 \ub9c8\uc9c0\ub9c9\uc5d0 \uc0ac\uc6a9\ud55c \uce74\ub204\uac00 \uc544\ub2cc $0$\ubc88 \uce74\ub204\ub97c \ubd80 \ub385\ud074\ub809\uc740 \uc6b4\ud56d\ud560 \uc218 \uc788\ub2e4. $0$\ubc88 \uce74\ub204\ub97c \ub2e4\uc2dc \uc6b4\ud56d\ud558\uba74, \ubd80 \ub385\ud074\ub809\uc740 \uc774\uc81c \uc12c $0$\uc5d0 \uc788\uac8c \ub41c\ub2e4. \ud558\uc9c0\ub9cc $1$, $2$, $4$\ubc88 \uce74\ub204\uac00 \uc5ec\ud589 \uc774\uc804\uacfc \uac19\uc740 \uc12c\uc5d0 \uc815\ubc15\ud574 \uc788\uc9c0 \uc54a\ub2e4. \ubd80 \ub385\ud074\ub809\uc740 \uc5ec\ud589\uc744 \uacc4\uc18d \uc774\uc5b4\uc11c $3$, $2$, $1$, $4$, $3$\ubc88 \uce74\ub204\ub97c \uc6b4\ud56d\ud55c\ub2e4. \ubd80 \ub385\ud074\ub809\uc740 \uc12c $0$\uc73c\ub85c \ub3cc\uc544\uc624\uace0 \ubaa8\ub4e0 \uce74\ub204\ub4e4\ub3c4 \uc5ec\ud589 \uc804\uacfc \ub3d9\uc77c\ud55c \uc12c\uc5d0 \uc815\ubc15\ud574 \uc788\ub2e4.<\/p>\r\n\r\n<p>\ub530\ub77c\uc11c, \ub9ac\ud134 \uac12 $[0, 1, 2, 4, 0, 3, 2, 1, 4, 3]$\uc740 \uc720\ud6a8\ud55c \uc5ec\ud589\uc744 \ub098\ud0c0\ub0b8\ub2e4.<\/p>\r\n","custom_example2":"<p>\ub2e4\uc74c \ud638\ucd9c\uc744 \uc0dd\uac01\ud574\ubcf4\uc790:<\/p>\r\n\r\n<pre>\r\n<code>find_journey(2, 3, [0, 1, 1], [1, 0, 0])\r\n<\/code><\/pre>\r\n\r\n<p>\uc12c\ub4e4\uacfc \uce74\ub204\ub4e4\uc740 \uc544\ub798 \uadf8\ub9bc\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/67bc8c30-0710-4377-85c9-15a16ddd2696\/-\/preview\/\" style=\"width: 251px; height: 104px;\" \/><\/p>\r\n\r\n<p>\ubd80 \ub385\ud074\ub809\uc740 $0$\ubc88 \uce74\ub204\ub97c \uc6b4\ud56d\ud574\uc57c\ub9cc \ud558\uace0, \uadf8 \ub2e4\uc74c \uadf8\ub140\ub294 $1$ \ub610\ub294 $2$\ubc88 \uce74\ub204\ub97c \uc6b4\ud56d\ud560 \uc218 \uc788\ub2e4. \ucc38\uace0\ub85c \uadf8\ub140\ub294 $0$\ubc88 \uce74\ub204\ub97c \uc5f0\uc18d\ud574\uc11c \uc6b4\ud56d\ud560 \uc218 \uc5c6\ub2e4. \uc5b4\ub290 \uacbd\uc6b0\ub358\uc9c0 \ubd80 \ub385\ud074\ub809\uc740 \uc12c $0$\uc73c\ub85c \ub3cc\uc544\uac04\ub2e4. \ud558\uc9c0\ub9cc, \uce74\ub204\ub4e4\uc740 \uc5ec\ud589 \uc804\uacfc \uac19\uc740 \uc12c\uc5d0 \uc815\ubc15\ud574 \uc788\uc9c0 \uc54a\uace0, \uc12c $0$\uc5d0 \uc815\ubc15\ud55c \uc720\uc77c\ud55c \uce74\ub204\ub294 \ubc29\uae08 \uadf8\ub140\uac00 \uc0ac\uc6a9\ud55c \uce74\ub204\ub77c\uc11c \ubd80 \ub385\ud074\ub809\uc740 \ub354 \uc774\uc0c1 \uc6b4\ud56d\ud560 \uc218 \uc788\ub294 \uce74\ub204\uac00 \uc5c6\ub2e4. \uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc5c6\uc73c\ubbc0\ub85c, \uc774 \ud568\uc218\ub294 <code>false<\/code>\ub97c \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/p>\r\n","custom_subtask_scoring_a":"<p>\uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc874\uc7ac\ud558\ub294 \uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0 \ub300\ud574, \ub2f9\uc2e0\uc758 \ub2f5\uc740:<\/p>\r\n\r\n<ul>\r\n\t<li>\uc720\ud6a8\ud55c \uc5ec\ud589\uc744 \ub9ac\ud134\ud55c \uacbd\uc6b0 \ub9cc\uc810\uc744 \ubc1b\uace0,<\/li>\r\n\t<li><code>true<\/code>\ub97c \ub9ac\ud134\ud558\uac70\ub098, $2\\,000\\,000$\uac1c\ubcf4\ub2e4 \ub9ce\uc740 \uc815\uc218\uac12\uc744 \uac16\ub294 \ubc30\uc5f4\uc744 \ub9ac\ud134\ud558\uac70\ub098, \ub610\ub294 \uc720\ud6a8\ud55c \uc5ec\ud589\uc744 \ub098\ud0c0\ub0b4\uc9c0 \uc54a\ub294 \uc815\uc218 \ubc30\uc5f4\uc744 \ub9ac\ud134\ud55c \uacbd\uc6b0 $35%$\uc758 \uc810\uc218\ub97c \ubc1b\uace0,<\/li>\r\n\t<li>\uadf8 \uc678\uc758 \uacbd\uc6b0 $0$\uc810\uc744 \ubc1b\ub294\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc720\ud6a8\ud55c \uc5ec\ud589\uc774 \uc874\uc7ac\ud558\uc9c0 \uc54a\ub294 \uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0 \ub300\ud574, \ub2f9\uc2e0\uc758 \ub2f5\uc740:<\/p>\r\n\r\n<ul>\r\n\t<li><code>false<\/code>\ub97c \ub9ac\ud134\ud55c \uacbd\uc6b0 \ub9cc\uc810\uc744 \ubc1b\uace0,<\/li>\r\n\t<li>\uadf8 \uc678\uc758 \uacbd\uc6b0 $0$\uc810\uc744 \ubc1b\ub294\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ucc38\uace0\ub85c, \uac01 \uc11c\ube0c\ud0dc\uc2a4\ud06c\uc758 \ucd5c\uc885 \uc810\uc218\ub294 \uadf8 \uc11c\ube0c\ud0dc\uc2a4\ud06c\uc758 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub4e4\uc758 \ucd5c\uc18c \uc810\uc218\ub85c \uc815\ud574\uc9c4\ub2e4.<\/p>\r\n","custom_samplegrader":"<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\uc758 \uc785\ub825 \ud615\uc2dd\uc740 \ub2e4\uc74c\uacfc \uac19\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>line $1$: $N \\, M$<\/li>\r\n\t<li>line $2 + i$ ($0 \\le i \\le M - 1$): $U[i] \\, V[i]$<\/li>\r\n<\/ul>\r\n\r\n<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub2e4\uc74c \ud615\uc2dd\uc73c\ub85c \ub2f5\uc744 \ucd9c\ub825\ud55c\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li><code>find_journey<\/code>\uac00 <code>bool<\/code>\uc744 \ub9ac\ud134\ud55c\ub2e4\uba74:\r\n\r\n\t<ul>\r\n\t\t<li>line $1$: $0$<\/li>\r\n\t\t<li>line $2$: <code>find_journey<\/code>\uac00 <code>false<\/code>\ub97c \ub9ac\ud134\ud55c \uacbd\uc6b0 $0$, \uadf8 \uc678\uc758 \uacbd\uc6b0 $1$<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li><code>find_journey<\/code>\uac00 <code>int[]<\/code>\ub97c \ub9ac\ud134\ud55c\ub2e4\uba74(\ubc30\uc5f4\uc758 \uc6d0\uc18c\ub97c $c[0], c[1], \\ldots c[k-1]$\ub85c \ub450\uba74):\r\n\t<ul>\r\n\t\t<li>line $1$: $1$<\/li>\r\n\t\t<li>line $2$: $k$<\/li>\r\n\t\t<li>line $3$: $c[0] \\, c[1] \\, \\ldots \\, c[k-1]$<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/161a5c03-f217-4382-a389-923e1083138d\/\">islands.zip<\/a><\/li>\r\n<\/ul>\r\n"},{"problem_id":"25443","problem_lang":"1","title":"Thousands Islands","description":"<p>Thousands Islands is a group of beautiful islands located in the Java Sea. It consists of $N$ islands, numbered from $0$ to $N - 1$.<\/p>\r\n\r\n<p>There are $M$ canoes, numbered from $0$ to $M - 1$, that can be used to sail between islands. For each $i$ such that $0 \\le i \\le M - 1$, canoe $i$ can be docked either at island $U[i]$ or $V[i]$, and can be used to sail between islands $U[i]$ and $V[i]$. Specifically, when the canoe is docked at island $U[i]$, it can be used to sail from island $U[i]$ to island $V[i]$, after which the canoe becomes docked at island $V[i]$. Similarly, when the canoe is docked at island $V[i]$, it can be used to sail from island $V[i]$ to island $U[i]$, after which the canoe becomes docked at island $U[i]$. Initially, the canoe is docked at island $U[i]$. It is possible that multiple canoes can be used to sail between the same pair of islands. It is also possible that multiple canoes are docked at the same island.<\/p>\r\n\r\n<p>For safety reasons, a canoe needs to be maintained after every time it is sailed, which forbids the same canoe to be sailed two times in a row. That is, after using some canoe $i$, another canoe must be used before canoe $i$ can be used again.<\/p>\r\n\r\n<p>Bu Dengklek wants to plan a journey through some of the islands. Her journey is&nbsp;<strong>valid<\/strong>&nbsp;if and only if the following conditions are satisfied.<\/p>\r\n\r\n<ul>\r\n\t<li>She starts and ends her journey at island $0$.<\/li>\r\n\t<li>She visits at least one island other than island $0$.<\/li>\r\n\t<li>After the journey ends, each canoe is docked at the same island as it was before the journey. I.e., canoe $i$, for each $i$ such that $0 \\le i \\le M - 1$, must be docked at island $U[i]$.<\/li>\r\n<\/ul>\r\n\r\n<p>Help Bu Dengklek find any valid journey involving sailing at most $2\\,000\\,000$ times, or determine that no such valid journey exists. It can be proven that under the constraints specified in this task (see Constraints section), if a valid journey exists, there also exists a valid journey that does not involve sailing more than $2\\,000\\,000$ times.<\/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 100\\,000$<\/li>\r\n\t<li>$1 \\le M \\le 200\\,000$<\/li>\r\n\t<li>$0 \\le U[i] \\le N - 1$ and $0 \\le V[i] \\le N - 1$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/li>\r\n\t<li>$U[i] \\neq V[i]$ (for each $i$ such that $0 \\le i \\le M - 1$)<\/li>\r\n<\/ul>\r\n","subtask1":"<p>$N = 2$<\/p>\r\n","subtask2":"<p>$N \\le 400$. For each pair of distinct islands $x$ and $y$ ($0 \\le x \\lt y \\le N - 1$), there are exactly two canoes that can be used to sail between them. One of them is docked at island $x$, and the other one is docked at island $y$.<\/p>\r\n","subtask3":"<p>$N \\le 1000$, $M$ is even, and for each&nbsp;<strong>even<\/strong>&nbsp;$i$ such that $0 \\le i \\le M - 1$, canoes $i$ and $i + 1$ can both be used to sail between islands $U[i]$ and $V[i]$. Canoe $i$ is initially docked at island $U[i]$ and canoe $i + 1$ is initially docked at island $V[i]$. Formally, $U[i] = V[i + 1]$ and $V[i] = U[i + 1]$.<\/p>\r\n","subtask4":"<p>$N \\le 1000$, $M$ is even, and for each&nbsp;<strong>even<\/strong>&nbsp;$i$ such that $0 \\le i \\le M - 1$, canoes $i$ and $i + 1$ can both be used to sail between islands $U[i]$ and $V[i]$. Both canoes are initially docked at island $U[i]$. Formally, $U[i] = U[i + 1]$ and $V[i] = V[i + 1]$.<\/p>\r\n","subtask5":"<p>No additional constraints.<\/p>\r\n","custom_implementation":"<p>You should implement the following procedure:<\/p>\r\n\r\n<pre>\r\n<code>union(bool, int[]) find_journey(int N, int M, int[] U, int[] V)\r\n<\/code><\/pre>\r\n\r\n<ul>\r\n\t<li>$N$: the number of islands.<\/li>\r\n\t<li>$M$: the number of canoes.<\/li>\r\n\t<li>$U$, $V$: arrays of length $M$ describing the canoes.<\/li>\r\n\t<li>This procedure should return either a boolean or an array of integers.\r\n\t<ul>\r\n\t\t<li>If no valid journey exists, the procedure should return <code>false<\/code>.<\/li>\r\n\t\t<li>If a valid journey exists, you have two options:\r\n\t\t<ul>\r\n\t\t\t<li>To be awarded the full score, the procedure should return an array of at most $2\\,000\\,000$ integers representing a valid journey. More precisely, the elements of this array should be the numbers of the canoes that are used in the journey (in the order they are used).<\/li>\r\n\t\t\t<li>To be awarded a partial score, the procedure should return <code>true<\/code>, an array of more than $2\\,000\\,000$ integers, or an array of integers not describing a valid journey. (See the Subtasks section for more details.)<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/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>find_journey(4, 5, [0, 1, 2, 0, 3], [1, 2, 3, 3, 1])\r\n<\/code><\/pre>\r\n\r\n<p>The islands and canoes are shown in the picture below.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/1e037aef-d9b0-47c8-8953-6678fe50909d\/-\/preview\/\" style=\"width: 227px; height: 224px;\" \/><\/p>\r\n\r\n<p>One possible valid journey is as follows. Bu Dengklek first sails canoes $0$, $1$, $2$, and $4$ in that order. As a result, she is at island $1$. After that, Bu Dengklek can sail canoe $0$ again as it is currently docked at island $1$ and the last canoe she used is not canoe $0$. After sailing canoe $0$ again, Bu Dengklek is now at island $0$. However, canoes $1$, $2$ and $4$ are not docked at the same islands as they were before the journey. Bu Dengklek then continues her journey by sailing canoes $3$, $2$, $1$, $4$, and $3$ again. Bu Dengklek is back at island $0$ and all the canoes are docked at the same islands as before the journey.<\/p>\r\n\r\n<p>Therefore, the returned value $[0, 1, 2, 4, 0, 3, 2, 1, 4, 3]$ represents a valid journey.<\/p>\r\n","custom_example2":"<p>Consider the following call:<\/p>\r\n\r\n<pre>\r\n<code>find_journey(2, 3, [0, 1, 1], [1, 0, 0])\r\n<\/code><\/pre>\r\n\r\n<p>The islands and canoes are shown in the picture below.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/67bc8c30-0710-4377-85c9-15a16ddd2696\/-\/preview\/\" style=\"width: 251px; height: 104px;\" \/><\/p>\r\n\r\n<p>Bu Dengklek can only start by sailing canoe $0$, after which she can sail either canoe $1$ or $2$. Note that she cannot sail canoe $0$ twice in a row. In both cases, Bu Dengklek is back at island $0$. However, the canoes are not docked at the same islands as they were before the journey, and Bu Dengklek cannot sail any canoe afterwards, as the only canoe docked at island $0$ is the one she has just used. As there is no valid journey, the procedure should return <code>false<\/code>.<\/p>\r\n","custom_subtask_scoring_a":"<p>For each test case in which a valid journey exists, your solution:<\/p>\r\n\r\n<ul>\r\n\t<li>gets full points if it returns a valid journey,<\/li>\r\n\t<li>gets $35%$ of the points if it returns <code>true<\/code>, an array of more than $2\\,000\\,000$ integers, or an array that does not describe a valid journey,<\/li>\r\n\t<li>gets $0$ points otherwise.<\/li>\r\n<\/ul>\r\n\r\n<p>For each test case in which a valid journey does not exist, your solution:<\/p>\r\n\r\n<ul>\r\n\t<li>gets full points if it returns <code>false<\/code>,<\/li>\r\n\t<li>gets $0$ points otherwise.<\/li>\r\n<\/ul>\r\n\r\n<p>Note that the final score for each subtask is the minimum of the points for the test cases in the subtask.<\/p>\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 \\, M$<\/li>\r\n\t<li>line $2 + i$ ($0 \\le i \\le M - 1$): $U[i] \\, V[i]$<\/li>\r\n<\/ul>\r\n\r\n<p>The sample grader prints your answers in the following format:<\/p>\r\n\r\n<ul>\r\n\t<li>If <code>find_journey<\/code> returns a <code>bool<\/code>:\r\n\r\n\t<ul>\r\n\t\t<li>line $1$: $0$<\/li>\r\n\t\t<li>line $2$: $0$ if <code>find_journey<\/code> returns <code>false<\/code>, or $1$ otherwise.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>If <code>find_journey<\/code> returns an <code>int[]<\/code>, denote the elements of this array by $c[0], c[1], \\ldots c[k-1]$. The sample grader prints:\r\n\t<ul>\r\n\t\t<li>line $1$: $1$<\/li>\r\n\t\t<li>line $2$: $k$<\/li>\r\n\t\t<li>line $3$: $c[0] \\, c[1] \\, \\ldots \\, c[k-1]$<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","custom_attachment":"<ul>\r\n\t<li><a href=\"https:\/\/upload.acmicpc.net\/161a5c03-f217-4382-a389-923e1083138d\/\">islands.zip<\/a><\/li>\r\n<\/ul>\r\n"}]

샘플 그레이더

샘플 그레이더의 입력 형식은 다음과 같다:

  • line 1ドル$: $N ,円 M$
  • line 2ドル + i$ (0ドル \le i \le M - 1$): $U[i] ,円 V[i]$

샘플 그레이더는 다음 형식으로 답을 출력한다:

  • find_journeybool을 리턴한다면:
    • line 1ドル$: 0ドル$
    • line 2ドル$: find_journeyfalse를 리턴한 경우 0ドル,ドル 그 외의 경우 1ドル$
  • find_journeyint[]를 리턴한다면(배열의 원소를 $c[0], c[1], \ldots c[k-1]$로 두면):
    • line 1ドル$: 1ドル$
    • line 2ドル$: $k$
    • line 3ドル$: $c[0] ,円 c[1] ,円 \ldots ,円 c[k-1]$

첨부

출처

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

  • 문제를 만든 사람: Félix Moreno Peñarrubia

제출할 수 있는 언어

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

채점 및 기타 정보

  • 예제는 채점하지 않는다.
  • 이 문제의 채점 우선 순위는 2이다.
(追記) (追記ここまで)

출처

대학교 대회

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

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