Class Solution
-
- All Implemented Interfaces:
public final class Solution
2246 - Longest Path With Different Adjacent Characters.
Hard
You are given a tree (i.e. a connected, undirected graph that has no cycles) rooted at node
0
consisting ofn
nodes numbered from0
ton - 1
. The tree is represented by a 0-indexed arrayparent
of sizen
, whereparent[i]
is the parent of nodei
. Since node0
is the root,parent[0] == -1
.You are also given a string
s
of lengthn
, wheres[i]
is the character assigned to nodei
.Return the length of the longest path in the tree such that no pair of adjacent nodes on the path have the same character assigned to them.
Example 1:
Input: parent = -1,0,0,1,1,2, s = "abacbe"
Output: 3
Explanation: The longest path where each two adjacent nodes have different characters in the tree is the path: 0 -> 1 -> 3. The length of this path is 3, so 3 is returned.
It can be proven that there is no longer path that satisfies the conditions.
Example 2:
Input: parent = -1,0,0,0, s = "aabc"
Output: 3
Explanation: The longest path where each two adjacent nodes have different characters is the path: 2 -> 0 -> 3. The length of this path is 3, so 3 is returned.
Constraints:
n == parent.length == s.length
<code>1 <= n <= 10<sup>5</sup></code>
0 <= parent[i] <= n - 1
for alli >= 1
parent[0] == -1
parent
represents a valid tree.s
consists of only lowercase English letters.
-
-
Constructor Summary
Constructors Constructor Description Solution()
-
Method Summary
Modifier and Type Method Description final Integer
longestPath(IntArray parent, String s)
-
-
Method Detail
-
longestPath
final Integer longestPath(IntArray parent, String s)
-
-
-
-