Class Solution
- java.lang.Object
-
- g2201_2300.s2246_longest_path_with_different_adjacent_characters.Solution
-
public class Solution extends Object
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
0consisting ofnnodes numbered from0ton - 1. The tree is represented by a 0-indexed arrayparentof sizen, whereparent[i]is the parent of nodei. Since node0is the root,parent[0] == -1.You are also given a string
sof 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.length1 <= n <= 1050 <= parent[i] <= n - 1for alli >= 1parent[0] == -1parentrepresents a valid tree.sconsists of only lowercase English letters.
-
-
Constructor Summary
Constructors Constructor Description Solution()
-
-
-
Method Detail
-
longestPath
public int longestPath(int[] parent, String s)
-
-