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

문제

노드가 $n$개인 트리 $T$가 있다. 노드는 $1$부터 $n$까지 번호가 붙어있고, 각 노드에는 영문 대문자 알파벳 ('A' - 'Z') 레이블이 붙어있다. Bob은 $T$에서 길이가 가장 긴 단순 경로를 찾는 문제에 관심이 많다. 단순 경로란, 그래프/트리의 같은 노드를 두 번 이상 방문하지 않는 경로를 말한다.

옆에서 지켜보던 Alice는 Bob에게 아래 정의에 따라 "좋은 단순 경로"를 찾아보라고 했다. 임의의 단순 경로 $P$에 대해, 만약 $P$에 속한 노드들의 레이블을 순서대로 나열하여 문자열을 만들었을 때 같은 알파벳이 연속으로 반복되지 않으면 $P$를 "좋은 단순 경로"라 한다.

예를 들어 위의 트리는 $7$개의 노드를 포함하고 있다.

  • 경로 $1 \to 5 \to 7$은 노드 $3$개를 포함하는 단순 경로이지만 노드들의 알파벳을 나열하면 "AAZ"가 되어 'A'가 연속으로 반복되므로 "좋은 단순 경로"가 아니다.
  • 경로 $3 \to 2 \to 1$은 노드 $3$개를 포함하는 좋은 단순 경로이다. 노드들의 알파벳을 나열하면 "AXA"가 되고 같은 알파벳이 여러 번 등장하지만 연속으로 반복되지 않는다.
  • 경로 $3 \to 2 \to 1 \to 4$와 경로 $4 \to 1 \to 2 \to 3$은 노드 $4$개를 포함하는 좋은 단순 경로이다. 단, 이 두 개의 경로는 같은 노드들을 포함하므로 같은 경로로 간주한다. (예제 입출력 참고)
  • 경로 $7$ 혹은 경로 $4$ 처럼 노드를 $1$개만 포함하는 좋은 단순 경로도 존재한다.
  • 이 트리에서 가장 긴 좋은 단순 경로의 길이는 $4$이며, 길이가 $4$인 좋은 단순 경로는 단 하나 존재한다.

Alice와 Bob은 $T$에서 가장 긴 좋은 단순 경로의 길이가 무엇인지, 그리고 가장 긴 좋은 단순 경로의 개수가 몇 개인지 궁금해졌다. 둘을 도와 이 문제를 풀어보자.

입력

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

각 테스트 케이스는 세 줄에 걸쳐 주어진다. 첫 줄에 노드의 개수 $n$이 주어진다. 둘째 줄에 각 노드의 알파벳 레이블이 공백없이 길이 $n$인 문자열 형태로 주어진다. 셋째 줄에 각 노드의 부모 노드의 번호가 공백으로 구분되어 주어진다. 루트 노드의 부모는 $0$번으로 주어진다.

출력

각 테스트 케이스의 정답인 두 정수를 공백으로 구분하여 각 줄에 출력한다.

첫 번째 정수는 가장 긴 좋은 단순 경로의 길이 (노드의 수)를 나타내고, 두 번째 수는 서로 다른 좋은 단순 경로의 개수를 나타낸다.

제한

  • $1 ≤ T ≤ 10$
  • 각 노드의 레이블은 알파벳 대문자 ('A' - 'Z')이다.

서브태스크 1 (10점)

  • $1 ≤ n ≤ 1\,000$

서브태스크 2 (20점)

  • $1 ≤ n ≤ 100\,000$

예제 입력 1

6
7
AXAYABZ
0 1 2 1 1 5 5
7
QXZQQPZ
0 1 2 1 1 5 5
5
LGBOJ
4 4 4 0 4
5
AAABC
3 3 0 1 2
7
GGGGGGG
0 1 2 1 1 5 5
10
UUQYQYQQQU
3 8 8 8 2 8 3 0 6 8

예제 출력 1

4 1
3 2
3 6
2 2
1 7
5 1

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

예제 2: 노드의 알파벳 레이블을 제외하면 예제 1의 트리와 구조가 같다. 길이가 $3$인 두 개의 좋은 단순 경로는: $1\to 2 \to 3$과 $6 \to 5 \to 7$이다. 

예제 3: 이 트리의 길이 $3$인 모든 단순 경로가 좋은 단순 경로이다.

예제 4: $1 \to 4$와 $2 \to 5$ 두 개의 좋은 단순 경로가 가장 긴 단순 경로이다.

예제 5: 본문에서 언급된 것 처럼 길이가 $1$인 좋은 단순 경로도 존재할 수 있다.

[{"problem_id":"25123","problem_lang":"0","title":"\uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c","description":"<p>\ub178\ub4dc\uac00 $n$\uac1c\uc778 \ud2b8\ub9ac $T$\uac00 \uc788\ub2e4. \ub178\ub4dc\ub294 $1$\ubd80\ud130 $n$\uae4c\uc9c0 \ubc88\ud638\uac00 \ubd99\uc5b4\uc788\uace0, \uac01 \ub178\ub4dc\uc5d0\ub294 \uc601\ubb38 \ub300\ubb38\uc790 \uc54c\ud30c\ubcb3 (&#39;<code>A<\/code>&#39; - &#39;<code>Z<\/code>&#39;) \ub808\uc774\ube14\uc774 \ubd99\uc5b4\uc788\ub2e4. Bob\uc740 $T$\uc5d0\uc11c \uae38\uc774\uac00 \uac00\uc7a5 \uae34 \ub2e8\uc21c \uacbd\ub85c\ub97c \ucc3e\ub294 \ubb38\uc81c\uc5d0 \uad00\uc2ec\uc774 \ub9ce\ub2e4. \ub2e8\uc21c \uacbd\ub85c\ub780, \uadf8\ub798\ud504\/\ud2b8\ub9ac\uc758 \uac19\uc740 \ub178\ub4dc\ub97c \ub450 \ubc88 \uc774\uc0c1 \ubc29\ubb38\ud558\uc9c0 \uc54a\ub294 \uacbd\ub85c\ub97c \ub9d0\ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc606\uc5d0\uc11c \uc9c0\ucf1c\ubcf4\ub358 Alice\ub294 Bob\uc5d0\uac8c \uc544\ub798 \uc815\uc758\uc5d0 \ub530\ub77c &quot;\uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c&quot;\ub97c \ucc3e\uc544\ubcf4\ub77c\uace0 \ud588\ub2e4. \uc784\uc758\uc758 \ub2e8\uc21c \uacbd\ub85c $P$\uc5d0 \ub300\ud574, \ub9cc\uc57d $P$\uc5d0 \uc18d\ud55c \ub178\ub4dc\ub4e4\uc758 \ub808\uc774\ube14\uc744 \uc21c\uc11c\ub300\ub85c \ub098\uc5f4\ud558\uc5ec \ubb38\uc790\uc5f4\uc744 \ub9cc\ub4e4\uc5c8\uc744 \ub54c \uac19\uc740 \uc54c\ud30c\ubcb3\uc774 \uc5f0\uc18d\uc73c\ub85c \ubc18\ubcf5\ub418\uc9c0 \uc54a\uc73c\uba74 $P$\ub97c &quot;\uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c&quot;\ub77c \ud55c\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/76f16b8d-1baf-4668-9b01-d5361bb331a5\/-\/preview\/\" style=\"height: 283px; width: 408px;\" \/><\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 \uc704\uc758 \ud2b8\ub9ac\ub294 $7$\uac1c\uc758 \ub178\ub4dc\ub97c \ud3ec\ud568\ud558\uace0 \uc788\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\uacbd\ub85c $1 \\to 5 \\to 7$\uc740 \ub178\ub4dc $3$\uac1c\ub97c \ud3ec\ud568\ud558\ub294 \ub2e8\uc21c \uacbd\ub85c\uc774\uc9c0\ub9cc \ub178\ub4dc\ub4e4\uc758 \uc54c\ud30c\ubcb3\uc744 \ub098\uc5f4\ud558\uba74 &quot;<code>AAZ<\/code>&quot;\uac00 \ub418\uc5b4 &#39;<code>A<\/code>&#39;\uac00 \uc5f0\uc18d\uc73c\ub85c \ubc18\ubcf5\ub418\ubbc0\ub85c &quot;\uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c&quot;\uac00 \uc544\ub2c8\ub2e4.<\/li>\r\n\t<li>\uacbd\ub85c $3 \\to 2 \\to 1$\uc740 \ub178\ub4dc $3$\uac1c\ub97c \ud3ec\ud568\ud558\ub294 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc774\ub2e4. \ub178\ub4dc\ub4e4\uc758 \uc54c\ud30c\ubcb3\uc744 \ub098\uc5f4\ud558\uba74 &quot;<code>AXA<\/code>&quot;\uac00 \ub418\uace0 \uac19\uc740 \uc54c\ud30c\ubcb3\uc774 \uc5ec\ub7ec \ubc88 \ub4f1\uc7a5\ud558\uc9c0\ub9cc \uc5f0\uc18d\uc73c\ub85c \ubc18\ubcf5\ub418\uc9c0 \uc54a\ub294\ub2e4.<\/li>\r\n\t<li>\uacbd\ub85c $3 \\to 2 \\to 1 \\to 4$\uc640 \uacbd\ub85c $4 \\to 1 \\to 2 \\to 3$\uc740 \ub178\ub4dc $4$\uac1c\ub97c \ud3ec\ud568\ud558\ub294 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc774\ub2e4. \ub2e8, \uc774 \ub450 \uac1c\uc758 \uacbd\ub85c\ub294 \uac19\uc740 \ub178\ub4dc\ub4e4\uc744 \ud3ec\ud568\ud558\ubbc0\ub85c \uac19\uc740 \uacbd\ub85c\ub85c \uac04\uc8fc\ud55c\ub2e4. (\uc608\uc81c \uc785\ucd9c\ub825 \ucc38\uace0)<\/li>\r\n\t<li>\uacbd\ub85c $7$ \ud639\uc740 \uacbd\ub85c $4$ \ucc98\ub7fc \ub178\ub4dc\ub97c $1$\uac1c\ub9cc \ud3ec\ud568\ud558\ub294 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\ub3c4 \uc874\uc7ac\ud55c\ub2e4.<\/li>\r\n\t<li>\uc774 \ud2b8\ub9ac\uc5d0\uc11c \uac00\uc7a5 \uae34 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc758 \uae38\uc774\ub294 $4$\uc774\uba70, \uae38\uc774\uac00 $4$\uc778 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\ub294 \ub2e8 \ud558\ub098 \uc874\uc7ac\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>Alice\uc640 Bob\uc740 $T$\uc5d0\uc11c \uac00\uc7a5 \uae34 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc758 \uae38\uc774\uac00 \ubb34\uc5c7\uc778\uc9c0, \uadf8\ub9ac\uace0 \uac00\uc7a5 \uae34 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc758 \uac1c\uc218\uac00 \uba87 \uac1c\uc778\uc9c0 \uad81\uae08\ud574\uc84c\ub2e4. \ub458\uc744 \ub3c4\uc640 \uc774 \ubb38\uc81c\ub97c \ud480\uc5b4\ubcf4\uc790.<\/p>\r\n","input":"<p>\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\ub294 \uc138 \uc904\uc5d0 \uac78\uccd0 \uc8fc\uc5b4\uc9c4\ub2e4. \uccab \uc904\uc5d0 \ub178\ub4dc\uc758 \uac1c\uc218 $n$\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. \ub458\uc9f8 \uc904\uc5d0 \uac01 \ub178\ub4dc\uc758 \uc54c\ud30c\ubcb3 \ub808\uc774\ube14\uc774 \uacf5\ubc31\uc5c6\uc774 \uae38\uc774 $n$\uc778 \ubb38\uc790\uc5f4 \ud615\ud0dc\ub85c \uc8fc\uc5b4\uc9c4\ub2e4. \uc14b\uc9f8 \uc904\uc5d0 \uac01 \ub178\ub4dc\uc758 \ubd80\ubaa8 \ub178\ub4dc\uc758 \ubc88\ud638\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. \ub8e8\ud2b8 \ub178\ub4dc\uc758 \ubd80\ubaa8\ub294 $0$\ubc88\uc73c\ub85c \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc815\ub2f5\uc778 \ub450 \uc815\uc218\ub97c \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ud558\uc5ec \uac01 \uc904\uc5d0 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<p>\uccab \ubc88\uc9f8 \uc815\uc218\ub294 \uac00\uc7a5 \uae34 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc758 \uae38\uc774 (\ub178\ub4dc\uc758 \uc218)\ub97c \ub098\ud0c0\ub0b4\uace0, \ub450 \ubc88\uc9f8 \uc218\ub294 \uc11c\ub85c \ub2e4\ub978 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc758 \uac1c\uc218\ub97c \ub098\ud0c0\ub0b8\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>\uac01 \ub178\ub4dc\uc758 \ub808\uc774\ube14\uc740 \uc54c\ud30c\ubcb3 \ub300\ubb38\uc790 (&#39;<code>A<\/code>&#39; - &#39;<code>Z<\/code>&#39;)\uc774\ub2e4.<\/li>\r\n<\/ul>\r\n","subtask1":"<ul>\r\n\t<li>$1 &le; n &le; 1\\,000$<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li>$1 &le; n &le; 100\\,000$<\/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: \ub178\ub4dc\uc758 \uc54c\ud30c\ubcb3 \ub808\uc774\ube14\uc744 \uc81c\uc678\ud558\uba74 \uc608\uc81c 1\uc758 \ud2b8\ub9ac\uc640 \uad6c\uc870\uac00 \uac19\ub2e4. \uae38\uc774\uac00 $3$\uc778 \ub450 \uac1c\uc758 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\ub294: $1\\to 2 \\to 3$\uacfc $6 \\to 5 \\to 7$\uc774\ub2e4.&nbsp;<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/d758912d-7d2c-487e-991a-eb18b63e1074\/-\/preview\/\" style=\"height: 283px; width: 408px;\" \/><\/p>\r\n\r\n<p>\uc608\uc81c 3: \uc774 \ud2b8\ub9ac\uc758 \uae38\uc774 $3$\uc778 \ubaa8\ub4e0 \ub2e8\uc21c \uacbd\ub85c\uac00 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uc774\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/af1c3c30-3457-4e72-94b4-24a63e8535b5\/-\/preview\/\" style=\"height: 188px; width: 296px;\" \/><\/p>\r\n\r\n<p>\uc608\uc81c 4: $1 \\to 4$\uc640 $2 \\to 5$ \ub450 \uac1c\uc758 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\uac00 \uac00\uc7a5 \uae34 \ub2e8\uc21c \uacbd\ub85c\uc774\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e1d95ec9-c7a5-4c95-91ed-2096d3381fa0\/-\/preview\/\" style=\"height: 271px; width: 256px;\" \/><\/p>\r\n\r\n<p>\uc608\uc81c 5: \ubcf8\ubb38\uc5d0\uc11c \uc5b8\uae09\ub41c \uac83 \ucc98\ub7fc \uae38\uc774\uac00 $1$\uc778 \uc88b\uc740 \ub2e8\uc21c \uacbd\ub85c\ub3c4 \uc874\uc7ac\ud560 \uc218 \uc788\ub2e4.<\/p>\r\n"},{"problem_id":"25123","problem_lang":"1","title":"Nice Simple Paths","description":"<p>$T$ is a tree with $n$ nodes (that are numbered from $1$ to $n$) where each node is labeled with an uppercase English alphabet (&#39;<code>A<\/code>&#39; - &#39;<code>Z<\/code>&#39;). Bob is interested in finding longest simple&nbsp;paths in $T$ (a simple path is a path that does not visit the same node more than once).<\/p>\r\n\r\n<p>Alice, after watching Bob playing this game, suggested Bob to find &quot;nice simple paths&quot; according to the following definition: For any simple path $P$, $P$ is said to be a &quot;nice simple path&quot; if the labels of the nodes&nbsp;in $P$ are written out to create a string such that the string does not have the same alphabet repeated consecutively.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/76f16b8d-1baf-4668-9b01-d5361bb331a5\/-\/preview\/\" style=\"height: 283px; width: 408px;\" \/><\/p>\r\n\r\n<p>For instance, the tree in the image above contains $7$ nodes.<\/p>\r\n\r\n<ul>\r\n\t<li>Path&nbsp;$1 \\to&nbsp;5 \\to 7$ is a simple path&nbsp;of $3$ nodes, but their labels produce the string &quot;<code>AAZ<\/code>&quot; in which &#39;<code>A<\/code>&#39; is repeated consecutively. This is not a nice simple path.<\/li>\r\n\t<li>Path $3 \\to&nbsp;2 \\to 1$ is a simple path of $3$ nodes, which is a nice simple path (their labels produce the string &quot;<code>AXA<\/code>&quot; where no alphabet is repeated consecutively).<\/li>\r\n\t<li>Paths&nbsp;$3 \\to&nbsp;2 \\to 1 \\to 4$ and $4 \\to 1 \\to 2 \\to 3$ are nice simple paths of $4$ nodes. Note that these two paths are considered as the same path since they contain the same set of nodes -- see the sample input and output.<\/li>\r\n\t<li>Paths $7$ and $4$ are nice simple paths that happen to contain only one node.<\/li>\r\n\t<li>The longest nice simple path in this tree contains $4$ nodes, and there exists only one longest nice simple path.<\/li>\r\n<\/ul>\r\n\r\n<p>Alice and Bob want to know the length of the longest nice simple paths in this tree, and how many different such paths exist. Help them compute the correct answer.<\/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>Each test case will consist of three lines. The first line will contain $n$, the number of nodes. The second line will contain a string of length $n$ (without space), describing the label of each node. The third line will contain $n$ numbers separated by whitespace, describing each node&#39;s parent node. The root node&#39;s parent will be given as $0$.<\/p>\r\n","output":"<p>For each test case, output two integers separated by whitespace.<\/p>\r\n\r\n<p>The first number must be the number of nodes contained in any longest nice simple path, and the second number must be the number of unique longest nice simple paths.<\/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>It is guaranteed that each node&#39;s label is one of uppercase English alphabets (&#39;<code>A<\/code>&#39; - &#39;<code>Z<\/code>&#39;).<\/li>\r\n<\/ul>\r\n","subtask1":"<ul>\r\n\t<li>$1 &le; n &le; 1\\,000$<\/li>\r\n<\/ul>\r\n","subtask2":"<ul>\r\n\t<li>$1 &le; n &le; 100\\,000$<\/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: This tree has the same structure as the one in Case 1, except for the node labels. There are two nice simple paths: $1\\to 2 \\to 3$ and $6 \\to 5 \\to 7$.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/d758912d-7d2c-487e-991a-eb18b63e1074\/-\/preview\/\" style=\"height: 283px; width: 408px;\" \/><\/p>\r\n\r\n<p>Case 3: Every simple path of length $3$ in the tree below is a nice simple path.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/af1c3c30-3457-4e72-94b4-24a63e8535b5\/-\/preview\/\" style=\"height: 188px; width: 296px;\" \/><\/p>\r\n\r\n<p>Case 4: $1 \\to 4$ and&nbsp;$2 \\to 5$ are the two longest nice simple paths.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/e1d95ec9-c7a5-4c95-91ed-2096d3381fa0\/-\/preview\/\" style=\"height: 271px; width: 256px;\" \/><\/p>\r\n\r\n<p>Case 5: As mentioned in the problem statement, nice simple paths may only contain one node.<\/p>\r\n"}]

시간 제한

  • Java 8: 3 초
  • Python 3: 4 초
  • PyPy3: 4 초
  • Java 8 (OpenJDK): 3 초
  • Java 11: 3 초
  • Kotlin (JVM): 3 초
  • Java 15: 3 초

채점 및 기타 정보

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