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

25685번 - 좋은 노드 집합 찾기 다국어

시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 (하단 참고)512 MB3551087231.169%

문제

Alice와 Bob은 트리를 이용한 놀이를 즐겨한다. n개의 노드를 가진 트리 가 있고 노드는 편의상 번호가 1부터 n까지 붙어있다고 하자. i번 노드의 부모 노드는 p[i] 라 하고, 루트 노드의 경우 p[i] = 0 으로 정의한다. 마지막으로, 각 노드에는 정수 값이 부여되어있는데 이는 v[i]로 나타낸다.

예를 들어 위 그림 속의 트리는 n = 6, v = [30, 15, 10, 20, 15, 18] 이고 p = [0, 1, 1, 3, 3, 3]인 경우를 나타낸다. 각 노드 옆에 적힌 값이 노드에 부여된 정수 값이다. 이 트리의 경우 p[1] = 0 이므로 1이 루트 노드이고, 루트 노드를 제외한 모든 노드는 부모 노드를 갖는다.

이 트리의 임의의 노드 부분집합 S가 아래 조건을 만족하면 "좋은 노드 집합"이라 한다:

  • 조건 1: 어떤 노드 x가 S에 속해있다면 x와 연결된 부모/자식 노드(들)은 S에 속하지 않는다.
  • 조건 2: 자식 노드가 1개 이상인 어떤 노드 x가 S에 속하지 않았다면 x의 자식 노드(들)중 최소 하나의 노드는 S에 속한다.

예를 들어 위 트리에서 아래와 같은 노드 부분 집합을 살펴보자:

  • S = {}: 조건 2를 만족하지 못하므로 좋은 모드 집합이 아니다. 가령 3번 노드가 S에 속하지 않았기 때문에 {4, 5, 6}중 최소 하나의 노드는 S에 속해야 한다.
  • S = {3}: 두 조건을 모두 만족시키므로 좋은 노드 집합이다.
  • S = {1, 2, 3}: 조건 2는 만족하지만 조건 1을 만족하지 않는다.
  • S = {1, 4, 6}: 두 조건을 모두 만족시키므로 좋은 노드 집합이다.
  • S = {2, 3}: 두 조건을 모두 만족시키므로 좋은 노드 집합이다.

노드 부분집합 S의 점수는 (Score(S)) S에 속한 노드들의 정수 값을 모두 더한 값으로 정의하자. 위 예제의 경우 S = {1, 4, 5, 6}일 때 30 +たす 20 +たす 15 +たす 18 = 83으로 가장 높은 점수를 달성할 수 있다 (아래 그림 참고).

입력으로 트리에 대한 정보가 주어졌을 때 Alice와 Bob이 달성할 수 있는 좋은 노드 집합의 가장 높은 점수를 구해보자.

입력

입력 첫 줄에 테스트 케이스의 수 T가 주어진다.

각 테스트 케이스의 첫 줄에는 노드의 수 n이 주어진다. 둘째 줄에는 각 노드에 부여된 정수 값이 주어지는데 (v[1], ..., v[n]), n개의 정수가 공백으로 구분되어 주어진다. 셋째 줄에는 각 노드의 부모 노드 번호가 주어지는데 (p[1], ..., p[n]), n개의 정수가 공백으로 구분되어 주어진다.

출력

각 테스트 케이스의 정답을 각 줄에 출력한다.

제한

  • 1 ≤ T ≤ 10
  • 2 ≤ n ≤ 100,000
  • -109 ≤ v[i] ≤ 109 (i = 1, 2, ..., n)
  • 0 ≤ p[i] ≤ n (i = 1, 2, ..., n)
  • 각 테스트 케이스에 대해:
    • i = 1, 2, ..., n중 단 하나의 i값에 대해서만 p[i] = 0 이다
    • 모든 i에 대하여 p[i] ≠ i 이다

예제 입력 1

5
6
30 15 10 20 15 18
0 1 1 3 3 3
6
1 120 100 10 20 30
0 1 1 3 3 3
6
100 8 5 -20 -30 15
0 1 1 3 3 3
5
-1 -2 -3 -4 -5
2 3 4 5 0
2
-2022 2022
0 1

예제 출력 1

83
220
115
-6
2022

예제 1: 본문에서 다루었다.

예제 2: 본문의 예제와 같은 구조의 트리이지만 각 노드에 부여된 정수 값이 다르다.

이 경우 S = {2, 3}이 점수를 최대로 하는 좋은 노드 부분집합이다.

예제 3: 추가 설명 없음.

예제 4: 아래 그림은 입력으로 주어진 트리를 나타낸다. S = {4, 2}가 점수를 최대로 하는 좋은 노드 부분집합이다.

예제 5: 추가 설명 없음.

힌트

[{"problem_id":"25685","problem_lang":"0","title":"\uc88b\uc740 \ub178\ub4dc \uc9d1\ud569 \ucc3e\uae30","description":"<p>Alice\uc640 Bob\uc740 \ud2b8\ub9ac\ub97c \uc774\uc6a9\ud55c \ub180\uc774\ub97c \uc990\uaca8\ud55c\ub2e4. n\uac1c\uc758 \ub178\ub4dc\ub97c \uac00\uc9c4 \ud2b8\ub9ac \uac00 \uc788\uace0 \ub178\ub4dc\ub294 \ud3b8\uc758\uc0c1 \ubc88\ud638\uac00 1\ubd80\ud130 n\uae4c\uc9c0 \ubd99\uc5b4\uc788\ub2e4\uace0 \ud558\uc790. i\ubc88 \ub178\ub4dc\uc758 \ubd80\ubaa8 \ub178\ub4dc\ub294 p[i] \ub77c \ud558\uace0, \ub8e8\ud2b8 \ub178\ub4dc\uc758 \uacbd\uc6b0 p[i] = 0 \uc73c\ub85c \uc815\uc758\ud55c\ub2e4. \ub9c8\uc9c0\ub9c9\uc73c\ub85c, \uac01 \ub178\ub4dc\uc5d0\ub294 \uc815\uc218 \uac12\uc774 \ubd80\uc5ec\ub418\uc5b4\uc788\ub294\ub370 \uc774\ub294 v[i]\ub85c \ub098\ud0c0\ub0b8\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/2bd87b09-86d1-408f-93b3-3df7c388b384\/-\/preview\/\" style=\"height: 243px; width: 400px;\" \/><\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 \uc704 \uadf8\ub9bc \uc18d\uc758 \ud2b8\ub9ac\ub294 n = 6, v = [30, 15, 10, 20, 15, 18] \uc774\uace0 p = [0, 1, 1, 3, 3, 3]\uc778 \uacbd\uc6b0\ub97c \ub098\ud0c0\ub0b8\ub2e4. \uac01 \ub178\ub4dc \uc606\uc5d0 \uc801\ud78c \uac12\uc774 \ub178\ub4dc\uc5d0 \ubd80\uc5ec\ub41c \uc815\uc218 \uac12\uc774\ub2e4. \uc774 \ud2b8\ub9ac\uc758 \uacbd\uc6b0 p[1] = 0 \uc774\ubbc0\ub85c 1\uc774 \ub8e8\ud2b8 \ub178\ub4dc\uc774\uace0, \ub8e8\ud2b8 \ub178\ub4dc\ub97c \uc81c\uc678\ud55c \ubaa8\ub4e0 \ub178\ub4dc\ub294 \ubd80\ubaa8 \ub178\ub4dc\ub97c \uac16\ub294\ub2e4.<\/p>\r\n\r\n<p>\uc774 \ud2b8\ub9ac\uc758 \uc784\uc758\uc758 \ub178\ub4dc \ubd80\ubd84\uc9d1\ud569 S\uac00 \uc544\ub798 \uc870\uac74\uc744 \ub9cc\uc871\ud558\uba74 &quot;\uc88b\uc740 \ub178\ub4dc \uc9d1\ud569&quot;\uc774\ub77c \ud55c\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>\uc870\uac74 1: \uc5b4\ub5a4 \ub178\ub4dc x\uac00 S\uc5d0 \uc18d\ud574\uc788\ub2e4\uba74 x\uc640 \uc5f0\uacb0\ub41c \ubd80\ubaa8\/\uc790\uc2dd \ub178\ub4dc(\ub4e4)\uc740 S\uc5d0 \uc18d\ud558\uc9c0 \uc54a\ub294\ub2e4.<\/li>\r\n\t<li>\uc870\uac74 2: \uc790\uc2dd \ub178\ub4dc\uac00 1\uac1c \uc774\uc0c1\uc778 \uc5b4\ub5a4 \ub178\ub4dc x\uac00 S\uc5d0 \uc18d\ud558\uc9c0 \uc54a\uc558\ub2e4\uba74 x\uc758 \uc790\uc2dd \ub178\ub4dc(\ub4e4)\uc911 \ucd5c\uc18c \ud558\ub098\uc758 \ub178\ub4dc\ub294 S\uc5d0 \uc18d\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 \uc704 \ud2b8\ub9ac\uc5d0\uc11c \uc544\ub798\uc640 \uac19\uc740 \ub178\ub4dc \ubd80\ubd84 \uc9d1\ud569\uc744 \uc0b4\ud3b4\ubcf4\uc790:<\/p>\r\n\r\n<ul>\r\n\t<li>S = {}: \uc870\uac74 2\ub97c \ub9cc\uc871\ud558\uc9c0 \ubabb\ud558\ubbc0\ub85c \uc88b\uc740 \ubaa8\ub4dc \uc9d1\ud569\uc774 \uc544\ub2c8\ub2e4. \uac00\ub839 3\ubc88 \ub178\ub4dc\uac00 S\uc5d0 \uc18d\ud558\uc9c0 \uc54a\uc558\uae30 \ub54c\ubb38\uc5d0 {4, 5, 6}\uc911 \ucd5c\uc18c \ud558\ub098\uc758 \ub178\ub4dc\ub294 S\uc5d0 \uc18d\ud574\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>S = {3}: \ub450 \uc870\uac74\uc744 \ubaa8\ub450 \ub9cc\uc871\uc2dc\ud0a4\ubbc0\ub85c \uc88b\uc740 \ub178\ub4dc \uc9d1\ud569\uc774\ub2e4.<\/li>\r\n\t<li>S = {1, 2, 3}: \uc870\uac74 2\ub294 \ub9cc\uc871\ud558\uc9c0\ub9cc \uc870\uac74 1\uc744 \ub9cc\uc871\ud558\uc9c0 \uc54a\ub294\ub2e4.<\/li>\r\n\t<li>S = {1, 4, 6}: \ub450 \uc870\uac74\uc744 \ubaa8\ub450 \ub9cc\uc871\uc2dc\ud0a4\ubbc0\ub85c \uc88b\uc740 \ub178\ub4dc \uc9d1\ud569\uc774\ub2e4.<\/li>\r\n\t<li>S = {2, 3}: \ub450 \uc870\uac74\uc744 \ubaa8\ub450 \ub9cc\uc871\uc2dc\ud0a4\ubbc0\ub85c \uc88b\uc740 \ub178\ub4dc \uc9d1\ud569\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ub178\ub4dc \ubd80\ubd84\uc9d1\ud569 S\uc758 \uc810\uc218\ub294 (Score(S)) S\uc5d0 \uc18d\ud55c \ub178\ub4dc\ub4e4\uc758 \uc815\uc218 \uac12\uc744 \ubaa8\ub450 \ub354\ud55c \uac12\uc73c\ub85c \uc815\uc758\ud558\uc790. \uc704 \uc608\uc81c\uc758 \uacbd\uc6b0 S = {1, 4, 5, 6}\uc77c \ub54c 30 + 20 + 15 + 18 = 83\uc73c\ub85c \uac00\uc7a5 \ub192\uc740 \uc810\uc218\ub97c \ub2ec\uc131\ud560 \uc218 \uc788\ub2e4 (\uc544\ub798 \uadf8\ub9bc \ucc38\uace0).<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/650689e9-78c0-4108-b4df-263a1da1be9e\/-\/preview\/\" \/><\/p>\r\n\r\n<p>\uc785\ub825\uc73c\ub85c \ud2b8\ub9ac\uc5d0 \ub300\ud55c \uc815\ubcf4\uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c Alice\uc640 Bob\uc774 \ub2ec\uc131\ud560 \uc218 \uc788\ub294 \uc88b\uc740 \ub178\ub4dc \uc9d1\ud569\uc758 \uac00\uc7a5 \ub192\uc740 \uc810\uc218\ub97c \uad6c\ud574\ubcf4\uc790.<\/p>\r\n","input":"<p>\uc785\ub825 \uccab \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc218 T\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uccab \uc904\uc5d0\ub294 \ub178\ub4dc\uc758 \uc218 n\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. \ub458\uc9f8 \uc904\uc5d0\ub294 \uac01 \ub178\ub4dc\uc5d0 \ubd80\uc5ec\ub41c \uc815\uc218 \uac12\uc774 \uc8fc\uc5b4\uc9c0\ub294\ub370 (v[1], ..., v[n]), n\uac1c\uc758 \uc815\uc218\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. \uc14b\uc9f8 \uc904\uc5d0\ub294 \uac01 \ub178\ub4dc\uc758 \ubd80\ubaa8 \ub178\ub4dc \ubc88\ud638\uac00 \uc8fc\uc5b4\uc9c0\ub294\ub370 (p[1], ..., p[n]), n\uac1c\uc758 \uc815\uc218\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc815\ub2f5\uc744 \uac01 \uc904\uc5d0 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>1 &le; T &le; 10<\/li>\r\n\t<li>2 &le; n &le; 100,000<\/li>\r\n\t<li>-10<sup>9<\/sup> &le; v[i] &le; 10<sup>9<\/sup> (i = 1, 2, ..., n)<\/li>\r\n\t<li>0 &le; p[i] &le; n (i = 1, 2, ..., n)<\/li>\r\n\t<li>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0 \ub300\ud574:\r\n\t<ul>\r\n\t\t<li>i = 1, 2, ..., n\uc911 \ub2e8 \ud558\ub098\uc758 i\uac12\uc5d0 \ub300\ud574\uc11c\ub9cc p[i] = 0 \uc774\ub2e4<\/li>\r\n\t\t<li>\ubaa8\ub4e0 i\uc5d0 \ub300\ud558\uc5ec p[i] &ne; i \uc774\ub2e4<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>\uc608\uc81c 1: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 2: \ubcf8\ubb38\uc758 \uc608\uc81c\uc640 \uac19\uc740 \uad6c\uc870\uc758 \ud2b8\ub9ac\uc774\uc9c0\ub9cc \uac01 \ub178\ub4dc\uc5d0 \ubd80\uc5ec\ub41c \uc815\uc218 \uac12\uc774 \ub2e4\ub974\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/517762f1-f73d-40f2-b454-37aadf3ab98e\/-\/preview\/\" \/><\/p>\r\n\r\n<p>\uc774 \uacbd\uc6b0 S = {2, 3}\uc774 \uc810\uc218\ub97c \ucd5c\ub300\ub85c \ud558\ub294 \uc88b\uc740 \ub178\ub4dc \ubd80\ubd84\uc9d1\ud569\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 3: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c.<\/p>\r\n\r\n<p>\uc608\uc81c 4: \uc544\ub798 \uadf8\ub9bc\uc740 \uc785\ub825\uc73c\ub85c \uc8fc\uc5b4\uc9c4 \ud2b8\ub9ac\ub97c \ub098\ud0c0\ub0b8\ub2e4. S = {4, 2}\uac00 \uc810\uc218\ub97c \ucd5c\ub300\ub85c \ud558\ub294 \uc88b\uc740 \ub178\ub4dc \ubd80\ubd84\uc9d1\ud569\uc774\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/ea3f3f45-18ee-4abe-ab68-67c854605cef\/-\/preview\/\" \/><\/p>\r\n\r\n<p>\uc608\uc81c 5: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c.<\/p>\r\n"},{"problem_id":"25685","problem_lang":"1","title":"Good Node-subsets","description":"<p>Alice and Bob like to play a game using trees. Let there be a tree with n nodes that are labeled from 1 to n. Let p[i] be the parent of node i, and let p[i] = 0 if node i is the root. Lastly, let v[i] be the integer value of node i assigned to it.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/2bd87b09-86d1-408f-93b3-3df7c388b384\/-\/preview\/\" style=\"height: 243px; width: 400px;\" \/><\/p>\r\n\r\n<p>For instance, the tree above describes the case where n = 6, v = [30, 15, 10, 20, 15, 18] and p = [0, 1, 1, 3, 3, 3]. The number next to each node is the integer value assigned to it. In this tree, p[1] = 0 indicates that node 1 is the root node. Notice that every node except for the root node has a parent node.<\/p>\r\n\r\n<p>If a node-subset S of the tree satisfies the following conditions, then we call it&nbsp;a &quot;good node-subset&quot;:<\/p>\r\n\r\n<ul>\r\n\t<li>Condition 1: If x is in S, then child\/parent node(s) of x (that are&nbsp;connected to&nbsp;x) are NOT in S.<\/li>\r\n\t<li>Condition 2: If x with 1 or more child node(s) is NOT in S, then at least one child node of x is in S.<\/li>\r\n<\/ul>\r\n\r\n<p>In the tree above, consider the following node-subsets:<\/p>\r\n\r\n<ul>\r\n\t<li>S = {}: Condition 2 is not satisfied --&nbsp;Node 3 is not in S, and thus at least one of {4, 5, 6} must be in S. Hence it is not a good node-subset.<\/li>\r\n\t<li>S = {3}: This is a good node-subset as it satisfies both conditions.<\/li>\r\n\t<li>S = {1, 2, 3}: Condition 2 is satisfied, but condition 1 is not.<\/li>\r\n\t<li>S = {1, 4, 6}: This is a good node-subset as it satisfies both conditions.<\/li>\r\n\t<li>S = {2, 3}: This is a good node-subset as it satisfies both conditions.<\/li>\r\n<\/ul>\r\n\r\n<p>Let Score(S) be the score of a good&nbsp;node-subset S where it is the sum of the values assigned to the nodes in S. In the above example, if S = {1, 4, 5, 6}, then Score(S) = 30 + 20 + 15 + 18 = 83, which is the highest score achievable.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/650689e9-78c0-4108-b4df-263a1da1be9e\/-\/preview\/\" \/><\/p>\r\n\r\n<p>Given a tree, compute the largest score of a good node-subset that Alice and Bob can achieve.<\/p>\r\n","input":"<p>The first line of the input will contain T, the number of test cases.<\/p>\r\n\r\n<p>The first line of each test case will contain n, the number of nodes. The second line will contain n integers separated by whitespace, describing the values assigned to nodes (v[1], ..., v[n]). The third line will contain n integers separated by whitespace, describing the parent of each node (p[1], ..., p[n]).<\/p>\r\n","output":"<p>Output the answer for each test case in each line.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>1 &le; T &le; 10<\/li>\r\n\t<li>2 &le; n &le; 100,000<\/li>\r\n\t<li>-10<sup>9<\/sup> &le; v[i] &le; 10<sup>9<\/sup> (i = 1, 2, ..., n)<\/li>\r\n\t<li>0 &le; p[i] &le; n (i = 1, 2, ..., n)<\/li>\r\n\t<li>For each test case:\r\n\t<ul>\r\n\t\t<li>Among i = 1, 2, ..., n, p[i] = 0 holds for exactly one i.<\/li>\r\n\t\t<li>For all i,&nbsp;p[i] &ne; i.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Case 1: Discussed in the problem statement.<\/p>\r\n\r\n<p>Case 2: It&#39;s the same tree as in Case 1, but the values assigned to nodes are different.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/517762f1-f73d-40f2-b454-37aadf3ab98e\/-\/preview\/\" \/><\/p>\r\n\r\n<p>In this case, S = {2, 3} maximizes the score.<\/p>\r\n\r\n<p>Case 3: No explanation.<\/p>\r\n\r\n<p>Case 4: The tree is shown below. S = {4, 2} maximizes the score. <\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/ea3f3f45-18ee-4abe-ab68-67c854605cef\/-\/preview\/\" \/><\/p>\r\n\r\n<p>Case 5: No explanation.<\/p>\r\n"}]

시간 제한

  • Java 8: 3 초
  • Python 3: 6 초
  • PyPy3: 6 초
  • Java 8 (OpenJDK): 3 초
  • Java 11: 3 초
  • Kotlin (JVM): 3 초
  • Java 15: 3 초
(追記) (追記ここまで)

출처

대학교 대회

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

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