시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 512 MB50111026.316%

문제

자카르타의 제일 큰 놀이동산에는 N 가지 놀이기구가 있는데, 0부터 N - 1까지 번호가 매겨져 있다. 이 탈 것들은 N - 1개의 양방향 도로로 연결되어 있어서, 어떤 두 놀이기구를 골라도 이 둘을 잇는 유일한 경로가 존재한다. 이 도로는 0부터 N - 2까지 번호가 매겨져 있다. i번 도로는 놀이기구 A[i]와 놀이기구 B[i]를 연결하고 걸어서 이동하는데 한 시간이 걸린다. 혼잡을 막기 위해서, 모든 놀이기구는 최대 3개의 도로와 연결되어 있다.  

모든 놀이기구를 정확하게 한 번 방문하는 행로(tour)를 만들려고 한다. 한 놀이기구에서 다른 놀이기구로 이동할 때 여러 도로를 지나가는 것은 지루하다. 즐거운 행로를 만들려면, 모든 놀이기구에 대해서 순서 관계를 정해서, 다음 놀이기구를 방문하는데 필요한 시간이 직전 놀이기구를 방문하는데 필요한 시간보다 길지 않게 하고 싶다. 다른 말로 하면, 0부터 N - 1까지 모든 정수가 정확하게 한 번씩 나오는 순열 P[0], P[1], …, P[N − 1]을 찾으려 하는데, 모든 0 < i < N − 1에 대해서 놀이기구 P[i]에서 놀이기구 P[i + 1]로 이동하는데 걸리는 시간이 놀이기구 P[i - 1]에서 놀이기구 P[i]로 이동하는데 걸리는 시간보다 길지 않다.

당신은 놀이기구의 전체 지도를 가지고 있지 않다. 따라서, 즐거운 행로를 만들려면 안내센터에 질문을 여러번 해야 한다. 최대 Q번 질문할 수 있고, 각각의 질문은 두 파라미터 X와 Y로 이루어지는데, 0 ≤ X, Y < N이다. 각 질문은 다음 둘 중 하나이다.  

  • 놀이기구 X에서 놀이기구 Y로 이동하는데 몇 시간 걸리는가? 특히 X = Y일 때, 답은 0이다.
  • 놀이기구 X와 놀이기구 Y가 주어졌을 때, 다음 조건을 만족하는 놀이기구 Z가 몇 개 있는가? 놀이기구 X에서 놀이기구 Z로 이동하려면 놀이기구 Y를 반드시 방문해야 한다. 놀이기구 Y도 포함된다. 특히 X = Y일 때, 답은 N이다.

할 일

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

  • createFunTour(N, Q) - 이 함수는 그레이더에 의해서 정확하게 한 번 호출된다.  
    • N: 놀이기구의 수를 나타내는 정수.  
    • Q: 질문의 최대 횟수를 나타내는 정수.  
    • 이 함수는 다음 두 그레이더 함수를 호출할 수 있다.  
      • hoursRequired(X, Y)
        • X: 첫번째 놀이기구를 표현하는 정수. 
        • Y: 두번째 놀이기구를 표현하는 정수.
        • 이 함수는 놀이기구 X에서 놀이기구 Y로 이동하는데 필요한 시간을 리턴한다. 
        • 만약 XY 중 어느 하나, 또는 둘 모두가 0 이상 N - 1 이하인 정수가 아니라면, WA를 받는다.  
      • attractionsBehind(X, Y)
        • X: 첫번째 놀이기구를 표현하는 정수.
        • Y: 두번째 놀이기구를 표현하는 정수.
        • 이 함수는 다음 조건을 만족하는 놀이기구 Z의 개수를 리턴하는데, 놀이기구 X에서 놀이기구 Z로 이동하려면 놀이기구 Y를 반드시 방문해야 한다.  
        • 만약 XY 중 어느 하나, 또는 둘 모두가 0 이상 N - 1 이하인 정수가 아니라면, WA를 받는다.
    • 이 함수는 즐거운 행로를 표현하는 N개의 정수의 순열을 저장한 배열을 리턴해야 한다.

예제

다음 예제에서, N = 7, Q = 400000, A = [0, 0, 0, 1, 1, 2], B = [1, 5, 6, 2, 4, 3]이다. 이 예제는 다음 그림으로 설명할 수 있다.

그레이더는 createFunTour(7, 400000)를 호출한다.

  • 만약 여러분이 hoursRequired(3, 5)로 질의하면, 리턴값은 4이다.
  • 만약 여러분이 hoursRequired(5, 4)로 질의하면, 리턴값은 3이다.
  • 만약 여러분이 attractionsBehind(5, 1)로 질의하면, 리턴값은 4이다. 놀이기구 5에서 놀이기구 1, 2, 3, 4로 가려면 놀이기구 1을 반드시 지나가야 한다.  
  • 만약 여러분이 attractionsBehind(1, 5)로 질의하면, 리턴값은 1이다.
  • 여러분의 가능한 리턴값 중 하나는 [3, 6, 4, 5, 2, 0, 1]인데, 다음 놀이기구를 방문하는데 필요한 시간은 차례대로 [4, 3, 3, 3, 2, 1]이기 때문이다.  

제한

  • 2 ≤ N ≤ 100000.
  • Q = 400000.
  • 어떤 두 놀이기구도 도로를 통해서 이동할 수 있다.
  • 각 놀이기구는 최대 3개의 도로와 연결되어 있다. (즉, 최대 3개 도로의 끝점이다.)

서브태스크 1 (10점)

  • N ≤ 17.

서브태스크 2 (16점)

  • N ≤ 500.

서브태스크 3 (21점)

  • 모든 1 ≤ i < N에 대해서 놀이기구 i와 놀이기구 ⌊(i−1)/2​⌋를 연결하는 도로가 있다.

서브태스크 4 (19점)

  • 모든 0 ≤ i < N에 대해서 hoursRequired(T, i) < 30를 만족하면서 다음 조건을 만족하는 구간 [L[i], R[i]] (0 ≤ L[i] ≤ iR[i] < N)이 존재하는 놀이도구 T가 최소한 하나 존재한다.    
    • 놀이기구 T에서 놀이기구 j로 이동하려면 놀이기구 i를 방문해야 한다는 것과,  L[i] ≤ jR[i]라는 것은 필요충분조건이다.
    • 만약 L[i] < i이라면, 다음 조건을 만족하는 놀이기구 X가 정확히 하나 존재한다.  
      • L[i] ≤ X < i.
      • 놀이기구 i와 놀이기구 X를 연결하는 도로가 있다.  
    • 만약 i < R[i]이라면, 다음 조건을 만족하는 놀이기구 Y가 정확히 하나 존재한다.  
      • i < YR[i].
      • 놀이기구 i와 놀이기구 Y를 연결하는 도로가 있다.  

서브태스크 5 (34점)

  • 추가적인 제약 조건이 없다.
[{"problem_id":"19620","problem_lang":"0","title":"\uc990\uac70\uc6b4 \ud589\ub85c","description":"<p>\uc790\uce74\ub974\ud0c0\uc758 \uc81c\uc77c \ud070 \ub180\uc774\ub3d9\uc0b0\uc5d0\ub294&nbsp;<em>N<\/em> \uac00\uc9c0 \ub180\uc774\uae30\uad6c\uac00 \uc788\ub294\ub370, 0\ubd80\ud130&nbsp;<em>N<\/em> - 1\uae4c\uc9c0 \ubc88\ud638\uac00 \ub9e4\uaca8\uc838 \uc788\ub2e4. \uc774 \ud0c8 \uac83\ub4e4\uc740&nbsp;<em>N<\/em> - 1\uac1c\uc758 \uc591\ubc29\ud5a5 \ub3c4\ub85c\ub85c \uc5f0\uacb0\ub418\uc5b4 \uc788\uc5b4\uc11c, \uc5b4\ub5a4 \ub450 \ub180\uc774\uae30\uad6c\ub97c \uace8\ub77c\ub3c4 \uc774 \ub458\uc744 \uc787\ub294 \uc720\uc77c\ud55c \uacbd\ub85c\uac00 \uc874\uc7ac\ud55c\ub2e4. \uc774 \ub3c4\ub85c\ub294&nbsp;0\ubd80\ud130&nbsp;<em>N<\/em> - 2\uae4c\uc9c0 \ubc88\ud638\uac00 \ub9e4\uaca8\uc838 \uc788\ub2e4. <em>i<\/em>\ubc88 \ub3c4\ub85c\ub294 \ub180\uc774\uae30\uad6c&nbsp;<em>A<\/em>[<em>i<\/em>]\uc640 \ub180\uc774\uae30\uad6c&nbsp;<em>B<\/em>[<em>i<\/em>]\ub97c \uc5f0\uacb0\ud558\uace0 \uac78\uc5b4\uc11c \uc774\ub3d9\ud558\ub294\ub370 \ud55c \uc2dc\uac04\uc774 \uac78\ub9b0\ub2e4. \ud63c\uc7a1\uc744 \ub9c9\uae30 \uc704\ud574\uc11c, \ubaa8\ub4e0 \ub180\uc774\uae30\uad6c\ub294 \ucd5c\ub300 3\uac1c\uc758 \ub3c4\ub85c\uc640 \uc5f0\uacb0\ub418\uc5b4 \uc788\ub2e4.&nbsp;&nbsp;<\/p>\r\n\r\n<p>\ubaa8\ub4e0 \ub180\uc774\uae30\uad6c\ub97c \uc815\ud655\ud558\uac8c \ud55c \ubc88 \ubc29\ubb38\ud558\ub294 \ud589\ub85c(tour)\ub97c \ub9cc\ub4e4\ub824\uace0 \ud55c\ub2e4. \ud55c \ub180\uc774\uae30\uad6c\uc5d0\uc11c \ub2e4\ub978 \ub180\uc774\uae30\uad6c\ub85c \uc774\ub3d9\ud560 \ub54c \uc5ec\ub7ec \ub3c4\ub85c\ub97c \uc9c0\ub098\uac00\ub294 \uac83\uc740 \uc9c0\ub8e8\ud558\ub2e4. \uc990\uac70\uc6b4 \ud589\ub85c\ub97c \ub9cc\ub4e4\ub824\uba74, \ubaa8\ub4e0 \ub180\uc774\uae30\uad6c\uc5d0 \ub300\ud574\uc11c \uc21c\uc11c \uad00\uacc4\ub97c \uc815\ud574\uc11c, \ub2e4\uc74c \ub180\uc774\uae30\uad6c\ub97c \ubc29\ubb38\ud558\ub294\ub370 \ud544\uc694\ud55c \uc2dc\uac04\uc774 \uc9c1\uc804 \ub180\uc774\uae30\uad6c\ub97c \ubc29\ubb38\ud558\ub294\ub370 \ud544\uc694\ud55c \uc2dc\uac04\ubcf4\ub2e4 \uae38\uc9c0 \uc54a\uac8c \ud558\uace0 \uc2f6\ub2e4. \ub2e4\ub978 \ub9d0\ub85c \ud558\uba74,&nbsp;0\ubd80\ud130&nbsp;<em>N<\/em> - 1\uae4c\uc9c0 \ubaa8\ub4e0 \uc815\uc218\uac00 \uc815\ud655\ud558\uac8c \ud55c \ubc88\uc529 \ub098\uc624\ub294 \uc21c\uc5f4 <em>P<\/em>[0], <em>P<\/em>[1], &hellip;, <em>P<\/em>[<em>N<\/em>&nbsp;&minus; 1]\uc744 \ucc3e\uc73c\ub824 \ud558\ub294\ub370,&nbsp;\ubaa8\ub4e0 0 &lt; <em>i<\/em> &lt; <em>N<\/em> &minus; 1\uc5d0 \ub300\ud574\uc11c \ub180\uc774\uae30\uad6c <em>P<\/em>[<em>i<\/em>]\uc5d0\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>P<\/em>[<em>i<\/em> + 1]\ub85c \uc774\ub3d9\ud558\ub294\ub370 \uac78\ub9ac\ub294 \uc2dc\uac04\uc774 \ub180\uc774\uae30\uad6c&nbsp;<em>P<\/em>[<em>i<\/em> - 1]\uc5d0\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>P<\/em>[<em>i<\/em>]\ub85c \uc774\ub3d9\ud558\ub294\ub370 \uac78\ub9ac\ub294 \uc2dc\uac04\ubcf4\ub2e4 \uae38\uc9c0 \uc54a\ub2e4.<\/p>\r\n\r\n<p>\ub2f9\uc2e0\uc740 \ub180\uc774\uae30\uad6c\uc758 \uc804\uccb4 \uc9c0\ub3c4\ub97c \uac00\uc9c0\uace0 \uc788\uc9c0 \uc54a\ub2e4. \ub530\ub77c\uc11c, \uc990\uac70\uc6b4 \ud589\ub85c\ub97c \ub9cc\ub4e4\ub824\uba74 \uc548\ub0b4\uc13c\ud130\uc5d0 \uc9c8\ubb38\uc744 \uc5ec\ub7ec\ubc88 \ud574\uc57c \ud55c\ub2e4. \ucd5c\ub300&nbsp;<em>Q<\/em>\ubc88 \uc9c8\ubb38\ud560 \uc218 \uc788\uace0, \uac01\uac01\uc758 \uc9c8\ubb38\uc740 \ub450 \ud30c\ub77c\ubbf8\ud130&nbsp;<em>X<\/em>\uc640&nbsp;<em>Y<\/em>\ub85c \uc774\ub8e8\uc5b4\uc9c0\ub294\ub370, 0 &le; <em>X<\/em>, <em>Y<\/em> &lt; <em>N<\/em>\uc774\ub2e4. \uac01 \uc9c8\ubb38\uc740 \ub2e4\uc74c \ub458 \uc911 \ud558\ub098\uc774\ub2e4.&nbsp;&nbsp;<\/p>\r\n\r\n<ul>\r\n\t<li>\ub180\uc774\uae30\uad6c&nbsp;<em>X<\/em>\uc5d0\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\ub85c \uc774\ub3d9\ud558\ub294\ub370 \uba87 \uc2dc\uac04 \uac78\ub9ac\ub294\uac00? \ud2b9\ud788&nbsp;<em>X<\/em> = <em>Y<\/em>\uc77c \ub54c, \ub2f5\uc740 0\uc774\ub2e4.<\/li>\r\n\t<li>\ub180\uc774\uae30\uad6c <em>X<\/em>\uc640 \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c, \ub2e4\uc74c \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294&nbsp;\ub180\uc774\uae30\uad6c&nbsp;<em>Z<\/em>\uac00 \uba87 \uac1c&nbsp;\uc788\ub294\uac00?&nbsp;\ub180\uc774\uae30\uad6c <em>X<\/em>\uc5d0\uc11c&nbsp;\ub180\uc774\uae30\uad6c <em>Z<\/em>\ub85c \uc774\ub3d9\ud558\ub824\uba74 \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\ub97c \ubc18\ub4dc\uc2dc \ubc29\ubb38\ud574\uc57c \ud55c\ub2e4.&nbsp;\ub180\uc774\uae30\uad6c <em>Y<\/em>\ub3c4 \ud3ec\ud568\ub41c\ub2e4. \ud2b9\ud788&nbsp;<em>X<\/em> = <em>Y<\/em>\uc77c \ub54c, \ub2f5\uc740 <em>N<\/em>\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n","input":"","output":"","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>2 &le; <em>N<\/em> &le; 100000.<\/li>\r\n\t<li><em>Q<\/em>&nbsp;= 400000.<\/li>\r\n\t<li>\uc5b4\ub5a4 \ub450 \ub180\uc774\uae30\uad6c\ub3c4 \ub3c4\ub85c\ub97c \ud1b5\ud574\uc11c \uc774\ub3d9\ud560 \uc218 \uc788\ub2e4.<\/li>\r\n\t<li>\uac01 \ub180\uc774\uae30\uad6c\ub294 \ucd5c\ub300 3\uac1c\uc758 \ub3c4\ub85c\uc640 \uc5f0\uacb0\ub418\uc5b4 \uc788\ub2e4. (\uc989, \ucd5c\ub300 3\uac1c \ub3c4\ub85c\uc758 \ub05d\uc810\uc774\ub2e4.)<\/li>\r\n<\/ul>\r\n","subtask1":"<ul>\r\n\t<li><em>N<\/em> &le; 17.<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li><em>N<\/em> &le; 500.<\/li>\r\n<\/ul>\r\n","subtask3":"<ul>\r\n\t<li>\ubaa8\ub4e0 1 &le; <em>i<\/em> &lt; <em>N<\/em>\uc5d0 \ub300\ud574\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>i<\/em>\uc640 \ub180\uc774\uae30\uad6c &lfloor;(<em>i<\/em>&minus;1)\/2\u200b&rfloor;\ub97c \uc5f0\uacb0\ud558\ub294 \ub3c4\ub85c\uac00 \uc788\ub2e4.<\/li>\r\n<\/ul>\r\n","subtask4":"<ul>\r\n\t<li>\ubaa8\ub4e0 0 &le; <em>i<\/em> &lt; <em>N<\/em>\uc5d0 \ub300\ud574\uc11c&nbsp;<code>hoursRequired(T, i)<\/code>&nbsp;&lt; 30\ub97c \ub9cc\uc871\ud558\uba74\uc11c&nbsp;\ub2e4\uc74c \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294 \uad6c\uac04&nbsp;[<em>L<\/em>[<em>i<\/em>], <em>R<\/em>[<em>i<\/em>]] (0 &le; <em>L<\/em>[<em>i<\/em>] &le; <em>i<\/em> &le; <em>R<\/em>[<em>i<\/em>] &lt; <em>N<\/em>)\uc774 \uc874\uc7ac\ud558\ub294 \ub180\uc774\ub3c4\uad6c&nbsp;<em>T<\/em>\uac00 \ucd5c\uc18c\ud55c \ud558\ub098 \uc874\uc7ac\ud55c\ub2e4.&nbsp;&nbsp;&nbsp;&nbsp;\r\n\t<ul>\r\n\t\t<li>\ub180\uc774\uae30\uad6c&nbsp;<em>T<\/em>\uc5d0\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>j<\/em>\ub85c \uc774\ub3d9\ud558\ub824\uba74 \ub180\uc774\uae30\uad6c&nbsp;<em>i<\/em>\ub97c \ubc29\ubb38\ud574\uc57c \ud55c\ub2e4\ub294 \uac83\uacfc,&nbsp; <em>L<\/em>[<em>i<\/em>] &le; <em>j<\/em> &le; <em>R<\/em>[<em>i<\/em>]\ub77c\ub294 \uac83\uc740 \ud544\uc694\ucda9\ubd84\uc870\uac74\uc774\ub2e4.<\/li>\r\n\t\t<li>\ub9cc\uc57d <em>L<\/em>[<em>i<\/em>] &lt; <em>i<\/em>\uc774\ub77c\uba74, \ub2e4\uc74c \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294 \ub180\uc774\uae30\uad6c&nbsp;<em>X<\/em>\uac00 \uc815\ud655\ud788 \ud558\ub098 \uc874\uc7ac\ud55c\ub2e4.&nbsp;&nbsp;\r\n\t\t<ul>\r\n\t\t\t<li><em>L<\/em>[<em>i<\/em>] &le; <em>X<\/em> &lt; <em>i<\/em>.<\/li>\r\n\t\t\t<li>\ub180\uc774\uae30\uad6c&nbsp;<em>i<\/em>\uc640 \ub180\uc774\uae30\uad6c&nbsp;<em>X<\/em>\ub97c \uc5f0\uacb0\ud558\ub294 \ub3c4\ub85c\uac00 \uc788\ub2e4.&nbsp;&nbsp;<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t\t<li>\ub9cc\uc57d <em>i<\/em>&nbsp;&lt; <em>R<\/em>[<em>i<\/em>]\uc774\ub77c\uba74, \ub2e4\uc74c \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294 \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\uac00 \uc815\ud655\ud788 \ud558\ub098 \uc874\uc7ac\ud55c\ub2e4.&nbsp;&nbsp;\r\n\t\t<ul>\r\n\t\t\t<li><em>i<\/em> &lt; <em>Y<\/em> &le; <em>R<\/em>[<em>i<\/em>].<\/li>\r\n\t\t\t<li>\ub180\uc774\uae30\uad6c&nbsp;<em>i<\/em>\uc640 \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\ub97c \uc5f0\uacb0\ud558\ub294 \ub3c4\ub85c\uac00 \uc788\ub2e4.&nbsp;&nbsp;<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","subtask5":"<ul>\r\n\t<li>\ucd94\uac00\uc801\uc778 \uc81c\uc57d \uc870\uac74\uc774 \uc5c6\ub2e4.<\/li>\r\n<\/ul>\r\n","custom_task":"<p>\ub2e4\uc74c&nbsp;<code>createFunTour<\/code>&nbsp;\ud568\uc218\ub97c \uad6c\ud604\ud574\uc57c \ud55c\ub2e4.&nbsp;&nbsp;<\/p>\r\n\r\n<ul>\r\n\t<li><code>createFunTour(N, Q)<\/code>&nbsp;- \uc774 \ud568\uc218\ub294 \uadf8\ub808\uc774\ub354\uc5d0 \uc758\ud574\uc11c \uc815\ud655\ud558\uac8c \ud55c \ubc88 \ud638\ucd9c\ub41c\ub2e4.&nbsp;&nbsp;\r\n\r\n\t<ul>\r\n\t\t<li><em>N<\/em>: \ub180\uc774\uae30\uad6c\uc758 \uc218\ub97c \ub098\ud0c0\ub0b4\ub294 \uc815\uc218.&nbsp;&nbsp;<\/li>\r\n\t\t<li><em>Q<\/em>: \uc9c8\ubb38\uc758 \ucd5c\ub300 \ud69f\uc218\ub97c \ub098\ud0c0\ub0b4\ub294 \uc815\uc218.&nbsp;&nbsp;<\/li>\r\n\t\t<li>\uc774 \ud568\uc218\ub294 \ub2e4\uc74c \ub450 \uadf8\ub808\uc774\ub354 \ud568\uc218\ub97c \ud638\ucd9c\ud560 \uc218 \uc788\ub2e4.&nbsp;&nbsp;\r\n\t\t<ul>\r\n\t\t\t<li><code>hoursRequired(X, Y)<\/code>\r\n\t\t\t<ul>\r\n\t\t\t\t<li><em>X<\/em>: \uccab\ubc88\uc9f8 \ub180\uc774\uae30\uad6c\ub97c \ud45c\ud604\ud558\ub294 \uc815\uc218.&nbsp;<\/li>\r\n\t\t\t\t<li><em>Y<\/em>: \ub450\ubc88\uc9f8 \ub180\uc774\uae30\uad6c\ub97c \ud45c\ud604\ud558\ub294 \uc815\uc218.<\/li>\r\n\t\t\t\t<li>\uc774 \ud568\uc218\ub294 \ub180\uc774\uae30\uad6c&nbsp;<em>X<\/em>\uc5d0\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\ub85c \uc774\ub3d9\ud558\ub294\ub370 \ud544\uc694\ud55c \uc2dc\uac04\uc744 \ub9ac\ud134\ud55c\ub2e4.&nbsp;<\/li>\r\n\t\t\t\t<li>\ub9cc\uc57d&nbsp;<em>X<\/em>,&nbsp;<em>Y<\/em> \uc911 \uc5b4\ub290 \ud558\ub098, \ub610\ub294 \ub458 \ubaa8\ub450\uac00 0&nbsp;\uc774\uc0c1&nbsp;<em>N<\/em> - 1 \uc774\ud558\uc778 \uc815\uc218\uac00 \uc544\ub2c8\ub77c\uba74, WA\ub97c \ubc1b\ub294\ub2e4.&nbsp;&nbsp;<\/li>\r\n\t\t\t<\/ul>\r\n\t\t\t<\/li>\r\n\t\t\t<li><code>attractionsBehind(X, Y)<\/code>\r\n\t\t\t<ul>\r\n\t\t\t\t<li><em>X<\/em>: \uccab\ubc88\uc9f8 \ub180\uc774\uae30\uad6c\ub97c \ud45c\ud604\ud558\ub294 \uc815\uc218.<\/li>\r\n\t\t\t\t<li><em>Y<\/em>: \ub450\ubc88\uc9f8 \ub180\uc774\uae30\uad6c\ub97c \ud45c\ud604\ud558\ub294 \uc815\uc218.<\/li>\r\n\t\t\t\t<li>\uc774 \ud568\uc218\ub294 \ub2e4\uc74c \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub294 \ub180\uc774\uae30\uad6c <em>Z<\/em>\uc758 \uac1c\uc218\ub97c \ub9ac\ud134\ud558\ub294\ub370, \ub180\uc774\uae30\uad6c <em>X<\/em>\uc5d0\uc11c \ub180\uc774\uae30\uad6c&nbsp;<em>Z<\/em>\ub85c \uc774\ub3d9\ud558\ub824\uba74 \ub180\uc774\uae30\uad6c&nbsp;<em>Y<\/em>\ub97c \ubc18\ub4dc\uc2dc \ubc29\ubb38\ud574\uc57c \ud55c\ub2e4.&nbsp;&nbsp;<\/li>\r\n\t\t\t\t<li>\ub9cc\uc57d <em>X<\/em>,&nbsp;<em>Y<\/em> \uc911 \uc5b4\ub290 \ud558\ub098, \ub610\ub294 \ub458 \ubaa8\ub450\uac00&nbsp;0 \uc774\uc0c1&nbsp;<em>N<\/em> - 1 \uc774\ud558\uc778 \uc815\uc218\uac00 \uc544\ub2c8\ub77c\uba74, WA\ub97c \ubc1b\ub294\ub2e4.<\/li>\r\n\t\t\t<\/ul>\r\n\t\t\t<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t\t<li>\uc774 \ud568\uc218\ub294 \uc990\uac70\uc6b4 \ud589\ub85c\ub97c \ud45c\ud604\ud558\ub294&nbsp;<em>N<\/em>\uac1c\uc758 \uc815\uc218\uc758 \uc21c\uc5f4\uc744 \uc800\uc7a5\ud55c \ubc30\uc5f4\uc744 \ub9ac\ud134\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","custom_example":"<p>\ub2e4\uc74c \uc608\uc81c\uc5d0\uc11c,&nbsp;<em>N<\/em> = 7, <em>Q<\/em> = 400000,&nbsp;<em>A<\/em> = [0, 0, 0, 1, 1, 2],&nbsp;<em>B<\/em> = [1, 5, 6, 2, 4, 3]\uc774\ub2e4. \uc774 \uc608\uc81c\ub294 \ub2e4\uc74c \uadf8\ub9bc\uc73c\ub85c \uc124\uba85\ud560 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/a9efbf95-118c-432c-ace8-2c74764789df\/-\/preview\/\" style=\"width: 280px; height: 250px;\" \/><\/p>\r\n\r\n<p>\uadf8\ub808\uc774\ub354\ub294&nbsp;<code>createFunTour(7, 400000)<\/code>\ub97c \ud638\ucd9c\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\ub9cc\uc57d \uc5ec\ub7ec\ubd84\uc774&nbsp;<code>hoursRequired(3, 5)<\/code>\ub85c \uc9c8\uc758\ud558\uba74, \ub9ac\ud134\uac12\uc740&nbsp;4\uc774\ub2e4.<\/li>\r\n\t<li>\ub9cc\uc57d \uc5ec\ub7ec\ubd84\uc774&nbsp;<code>hoursRequired(5, 4)<\/code>\ub85c \uc9c8\uc758\ud558\uba74, \ub9ac\ud134\uac12\uc740&nbsp;3\uc774\ub2e4.<\/li>\r\n\t<li>\ub9cc\uc57d \uc5ec\ub7ec\ubd84\uc774&nbsp;<code>attractionsBehind(5, 1)<\/code>\ub85c \uc9c8\uc758\ud558\uba74, \ub9ac\ud134\uac12\uc740 4\uc774\ub2e4. \ub180\uc774\uae30\uad6c 5\uc5d0\uc11c \ub180\uc774\uae30\uad6c 1, 2, 3, 4\ub85c \uac00\ub824\uba74 \ub180\uc774\uae30\uad6c 1\uc744 \ubc18\ub4dc\uc2dc \uc9c0\ub098\uac00\uc57c \ud55c\ub2e4.&nbsp;&nbsp;<\/li>\r\n\t<li>\ub9cc\uc57d \uc5ec\ub7ec\ubd84\uc774&nbsp;<code>attractionsBehind(1, 5)<\/code>\ub85c \uc9c8\uc758\ud558\uba74, \ub9ac\ud134\uac12\uc740&nbsp;1\uc774\ub2e4.<\/li>\r\n\t<li>\uc5ec\ub7ec\ubd84\uc758 \uac00\ub2a5\ud55c \ub9ac\ud134\uac12 \uc911 \ud558\ub098\ub294&nbsp;[3, 6, 4, 5, 2, 0, 1]\uc778\ub370, \ub2e4\uc74c \ub180\uc774\uae30\uad6c\ub97c \ubc29\ubb38\ud558\ub294\ub370 \ud544\uc694\ud55c \uc2dc\uac04\uc740 \ucc28\ub840\ub300\ub85c&nbsp;[4, 3, 3, 3, 2, 1]\uc774\uae30 \ub54c\ubb38\uc774\ub2e4.&nbsp;&nbsp;<\/li>\r\n<\/ul>\r\n","custom_grader":"<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \uc785\ub825\uc744 \ub2e4\uc74c \uc591\uc2dd\uc73c\ub85c \uc77d\ub294\ub2e4.&nbsp;<\/p>\r\n\r\n<pre>\r\nN Q\r\nA[0] B[0]\r\nA[1] B[1]\r\n.\r\n.\r\n.\r\nA[N-2] B[N-2]\r\n<\/pre>\r\n\r\n<p>\uc0d8\ud50c \uadf8\ub808\uc774\ub354\ub294 \ub9cc\uc57d&nbsp;<code>createFunTour&nbsp;<\/code>\ud568\uc218\uac00 \uc990\uac70\uc6b4 \ud589\ub85c\ub97c \ud45c\ud604\ud558\ub294&nbsp;<em>N<\/em>\uac1c\uc758 \uc815\uc218\uc758 \uc21c\uc5f4\uc744 \uc800\uc7a5\ud55c \ubc30\uc5f4\uc744 \uc815\ud655\ud788 \uad6c\ud558\uace0,&nbsp;<code>hoursRequired<\/code>,&nbsp;<code>attractionsBehind&nbsp;<\/code>\ud568\uc218\uc758&nbsp;\ud638\ucd9c \ud69f\uc218&nbsp;\ud569\uc774 <em>Q<\/em>\uc774\ud558\uc774\uba74 \uc774&nbsp;\ubc30\uc5f4\uc744 \ucd9c\ub825\ud55c\ub2e4. \uadf8\ub807\uc9c0 \uc54a\uc73c\uba74, \uc624\ub2f5 \uba54\uc2dc\uc9c0\ub97c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","custom_attachment":"<p>\uacf5\uac1c\ub41c \uadf8\ub808\uc774\ub354, \uc608\uc81c \ucf00\uc774\uc2a4, \ubb38\uc81c\uc5d0 \ub300\ud55c \uae30\ubcf8 \ud30c\uc77c\uc740&nbsp;<a href=\"https:\/\/upload.acmicpc.net\/51eb3e4e-e0db-43c1-9b83-bc20a0cff602\/\">\uc5ec\uae30<\/a>\uc5d0\uc11c \ubc1b\uc744 \uc218 \uc788\ub2e4.&nbsp;<\/p>\r\n"},{"problem_id":"19620","problem_lang":"1","title":"Fun Tour","description":"<p>There are <em>N<\/em>&nbsp;attractions in the biggest theme park in Jakarta, numbered from&nbsp;0 to&nbsp;<em>N<\/em> - 1. These attractions are connected by&nbsp;<em>N<\/em> - 1 bidirectional roads such that there is a unique path between any pair of attractions through the roads. The roads are numbered from&nbsp;0&nbsp;to&nbsp;<em>N<\/em> - 2. The <em>i<\/em>-th road connects the&nbsp;<em>A<\/em>[<em>i<\/em>]-th attraction and the&nbsp;<em>B<\/em>[<em>i<\/em>]-th attraction and takes one hour to walk through. To avoid congestion, each attraction is an endpoint of at most three roads.<\/p>\r\n\r\n<p>You would like to create a tour visiting all attractions exactly once. Going through many roads when going from an attraction to another is boring. To create a fun tour, you would like to find an ordering of all attractions, such that the time required to visit the next attraction is not longer than the time required to visit the previous attraction. In other words, you would like to find a sequence <em>P<\/em>[0], <em>P<\/em>[1], &hellip;, <em>P<\/em>[<em>N<\/em> - 1]&nbsp;containing all integers from&nbsp;0 to&nbsp;<em>N<\/em> - 1 exactly once such that the time required to go from the <em>P<\/em>[<em>i<\/em>]-th attraction to the <em>P<\/em>[<em>i<\/em> + 1]-th attraction is not longer than the time required to go from the&nbsp;<em>P<\/em>[<em>i<\/em> - 1]-th attraction to the&nbsp;<em>P<\/em>[<em>i<\/em>]-th attraction, for 0 &lt; <em>i<\/em> &lt; <em>N<\/em> - 1.<\/p>\r\n\r\n<p>You do not have the complete map of the attractions. Therefore, you have to ask several questions to the information centre to create a fun tour. You can ask at most <em>Q<\/em>&nbsp;questions, each with two parameters <em>X<\/em>&nbsp;and&nbsp;<em>Y<\/em>, where 0 &le; <em>X<\/em>, <em>Y<\/em> &lt; <em>N<\/em>. Each question is either of the following:<\/p>\r\n\r\n<ul>\r\n\t<li>How many hours are required to go from the&nbsp;<em>X<\/em>-th attraction to the <em>Y<\/em>-th attraction? In particular, if&nbsp;<em>X<\/em> = <em>Y<\/em>, the answer is&nbsp;0.<\/li>\r\n\t<li>How many attractions&nbsp;<em>Z<\/em> such that you have to visit the <em>Y<\/em>-th attraction to go from the <em>X<\/em>-th attraction to the&nbsp;<em>Z<\/em>-th attraction? The&nbsp;<em>Y<\/em>-th attraction will be counted as well. In particular, if&nbsp;<em>X<\/em> = <em>Y<\/em>, the answer is&nbsp;<em>N<\/em>.<\/li>\r\n<\/ul>\r\n","input":"","output":"","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>2 &le; <em>N<\/em> &le; 100000.<\/li>\r\n\t<li><em>Q<\/em>&nbsp;= 400000.<\/li>\r\n\t<li>It is possible to travel between any pair of attractions through the roads.<\/li>\r\n\t<li>Each attraction is an endpoint of at most three roads.<\/li>\r\n<\/ul>\r\n","subtask1":"<ul>\r\n\t<li><em>N<\/em> &le; 17.<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li><em>N<\/em> &le; 500.<\/li>\r\n<\/ul>\r\n","subtask3":"<ul>\r\n\t<li>There is a road connecting the <em>i<\/em>-th attraction and the &lfloor;(<em>i<\/em>&minus;1)\/2\u200b&rfloor;-th attraction, for all&nbsp;1 &le; <em>i<\/em> &lt; <em>N<\/em>.<\/li>\r\n<\/ul>\r\n","subtask4":"<ul>\r\n\t<li>There is at least an attraction&nbsp;<em>T<\/em> such that for all 0 &le; <em>i<\/em>&nbsp;&lt; <em>N<\/em>,&nbsp;<code>hoursRequired(T, i)<\/code>&nbsp;&lt; 30&nbsp;and there exists an interval&nbsp;[<em>L<\/em>[<em>i<\/em>], <em>R<\/em>[<em>i<\/em>]] (0 &le; <em>L<\/em>[<em>i<\/em>] &le; <em>i<\/em> &le; <em>R<\/em>[<em>i<\/em>] &lt; <em>N<\/em>)) satisfying the following conditions:\r\n\t<ul>\r\n\t\t<li>You have to visit the&nbsp;<em>i<\/em>-th attraction to go from the&nbsp;<em>T<\/em>-th attraction to the <em>j<\/em>-th attraction if and only if&nbsp;<em>L<\/em>[<em>i<\/em>] &le; <em>j<\/em> &le; <em>R<\/em>[<em>i<\/em>].<\/li>\r\n\t\t<li>If <em>L<\/em>[<em>i<\/em>] &lt; <em>i<\/em>, then there must be exactly one attraction&nbsp;<em>X<\/em> such that:\r\n\t\t<ul>\r\n\t\t\t<li><em>L<\/em>[<em>i<\/em>] &le; <em>X<\/em> &lt; <em>i<\/em>.<\/li>\r\n\t\t\t<li>There is a road connecting the&nbsp;<em>i<\/em>-th attraction and the&nbsp;<em>X<\/em>-th attraction.<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t\t<li><em>i<\/em> &lt; <em>R<\/em>[<em>i<\/em>], then there must be exactly one attraction&nbsp;<em>Y<\/em> such that:\r\n\t\t<ul>\r\n\t\t\t<li><em>i<\/em> &lt; <em>Y<\/em> &le; <em>R<\/em>[<em>i<\/em>].<\/li>\r\n\t\t\t<li>There is a road connecting the&nbsp;<em>i<\/em>-th attraction and the&nbsp;<em>Y<\/em>-th attraction.<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","subtask5":"","custom_task":"<p>You have to implement&nbsp;<code>createFunTour<\/code>&nbsp;function:<\/p>\r\n\r\n<ul>\r\n\t<li><code>createFunTour(N, Q)<\/code>&nbsp;- This function will be called by the grader exactly once.\r\n\r\n\t<ul>\r\n\t\t<li><em>N<\/em>: An integer representing the number of attractions.<\/li>\r\n\t\t<li><em>Q<\/em>: An integer representing the maximum number of questions.<\/li>\r\n\t\t<li>This function is allowed to call two grader functions:\r\n\t\t<ul>\r\n\t\t\t<li><code>hoursRequired(X, Y)<\/code>\r\n\t\t\t<ul>\r\n\t\t\t\t<li><em>X<\/em>: An integer representing the first attraction.<\/li>\r\n\t\t\t\t<li><em>Y<\/em>: An integer representing the second attraction.<\/li>\r\n\t\t\t\t<li>This function returns an integer representing hours required to go from the&nbsp;<em>X<\/em>-th attraction to the&nbsp;<em>Y<\/em>-th attraction.<\/li>\r\n\t\t\t\t<li>If either&nbsp;<em>X<\/em> or&nbsp;<em>Y<\/em> is not an integer between&nbsp;0 and&nbsp;<em>N<\/em> - 1, then you will get a WA verdict.<\/li>\r\n\t\t\t<\/ul>\r\n\t\t\t<\/li>\r\n\t\t\t<li><code>attractionsBehind(X, Y)<\/code>\r\n\t\t\t<ul>\r\n\t\t\t\t<li><em>X<\/em>: An integer representing the first attraction.<\/li>\r\n\t\t\t\t<li><em>Y<\/em>: An integer representing the second attraction.<\/li>\r\n\t\t\t\t<li>This function returns an integer representing the number of attractions <em>Z<\/em>&nbsp;such that you have to visit the&nbsp;<em>Y<\/em>-th attraction to go from the&nbsp;<em>X<\/em>-th attraction to the&nbsp;<em>Z<\/em>-th attraction.<\/li>\r\n\t\t\t\t<li>If either&nbsp;<em>X<\/em> or <em>Y<\/em>&nbsp;is not an integer between&nbsp;0&nbsp;and&nbsp;<em>N<\/em> - 1 then you will get a WA verdict.<\/li>\r\n\t\t\t<\/ul>\r\n\t\t\t<\/li>\r\n\t\t<\/ul>\r\n\t\t<\/li>\r\n\t\t<li>This function must return an array of&nbsp;<em>N<\/em>&nbsp;integers representing the permutation of attractions in a fun tour.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","custom_example":"<p>In the following example,&nbsp;<em>N<\/em> = 7, <em>Q<\/em> = 400000,&nbsp;<em>A<\/em> = [0, 0, 0, 1, 1, 2],&nbsp;<em>B<\/em> = [1, 5, 6, 2, 4, 3]. The example is illustrated by the following image:<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/a9efbf95-118c-432c-ace8-2c74764789df\/-\/preview\/\" style=\"width: 280px; height: 250px;\" \/><\/p>\r\n\r\n<p>Grader will call&nbsp;<code>createFunTour(7, 400000)<\/code>.<\/p>\r\n\r\n<ul>\r\n\t<li>If the contestant queries&nbsp;<code>hoursRequired(3, 5)<\/code>, then the function will return 4.<\/li>\r\n\t<li>If the contestant queries&nbsp;<code>hoursRequired(5, 4)<\/code>, then the function will return 3.<\/li>\r\n\t<li>If the contestant queries&nbsp;<code>attractionsBehind(5, 1)<\/code>, then the function will return 4. To go from the fifth attraction to the first, second, third, and fourth attractions, you will have to visit the first attraction.<\/li>\r\n\t<li>If the contestant queries&nbsp;<code>attractionsBehind(1, 5)<\/code>, then the function will return 1.<\/li>\r\n\t<li>The contestant can return&nbsp;[3, 6, 4, 5, 2, 0, 1] since the hours required to visit the next attractions are&nbsp;[4, 3, 3, 3, 2, 1] in order.<\/li>\r\n<\/ul>\r\n","custom_grader":"<p>The sample grader reads the input in the following format:<\/p>\r\n\r\n<pre>\r\nN Q\r\nA[0] B[0]\r\nA[1] B[1]\r\n.\r\n.\r\n.\r\nA[N-2] B[N-2]\r\n<\/pre>\r\n\r\n<p>The sample grader writes the integers returned by&nbsp;<code>createFunTour<\/code>&nbsp;if it correctly returns an array of <em>N<\/em>&nbsp;integers representing the permutation of attractions in a fun tour and calls both&nbsp;<code>hoursRequired<\/code>&nbsp;and&nbsp;<code>attractionsBehind<\/code>&nbsp;not more than&nbsp;<em>Q<\/em> times combined. Otherwise, it prints a wrong answer message.<\/p>\r\n","custom_attachment":"<p>The public grader, sample cases, and skeleton files for this problem is available&nbsp;<a href=\"https:\/\/upload.acmicpc.net\/51eb3e4e-e0db-43c1-9b83-bc20a0cff602\/\">here<\/a>.<\/p>\r\n"}]

샘플 그레이더

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

N Q
A[0] B[0]
A[1] B[1]
.
.
.
A[N-2] B[N-2]

샘플 그레이더는 만약 createFunTour 함수가 즐거운 행로를 표현하는 N개의 정수의 순열을 저장한 배열을 정확히 구하고, hoursRequiredattractionsBehind 함수의 호출 횟수 합이 Q이하이면 이 배열을 출력한다. 그렇지 않으면, 오답 메시지를 출력한다.

첨부

공개된 그레이더, 예제 케이스, 문제에 대한 기본 파일은 여기에서 받을 수 있다. 

제출할 수 있는 언어

C++17, Java 8, C++14, Java 8 (OpenJDK), Java 11, C++20, C++14 (Clang), C++17 (Clang), C++20 (Clang)

채점 및 기타 정보

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