Class Solution

  • All Implemented Interfaces:

    
    public final class Solution
    
                        

    3486 - Longest Special Path II.

    Hard

    You are given an undirected tree rooted at node 0, with n nodes numbered from 0 to n - 1. This is represented by a 2D array edges of length n - 1, where <code>edgesi = u<sub>i</sub>, v<sub>i</sub>, length<sub>i</sub></code> indicates an edge between nodes <code>u<sub>i</sub></code> and <code>v<sub>i</sub></code> with length <code>length<sub>i</sub></code>. You are also given an integer array nums, where nums[i] represents the value at node i.

    A special path is defined as a downward path from an ancestor node to a descendant node in which all node values are distinct , except for at most one value that may appear twice.

    Return an array result of size 2, where result[0] is the length of the longest special path, and result[1] is the minimum number of nodes in all possible longest special paths.

    Example 1:

    Input: edges = [0,1,1,1,2,3,1,3,1,2,4,6,4,7,2,3,5,2,3,6,5,6,8,3], nums = 1,1,0,3,1,2,1,1,0

    Output: 9,3

    Explanation:

    In the image below, nodes are colored by their corresponding values in nums.

    The longest special paths are 1 -&gt; 2 -&gt; 4 and 1 -&gt; 3 -&gt; 6 -&gt; 8, both having a length of 9. The minimum number of nodes across all longest special paths is 3.

    Example 2:

    Input: edges = [1,0,3,0,2,4,0,3,5], nums = 1,1,0,2

    Output: 5,2

    Explanation:

    The longest path is 0 -&gt; 3 consisting of 2 nodes with a length of 5.

    Constraints:

    • <code>2 <= n <= 5 * 10<sup>4</sup></code>

    • edges.length == n - 1

    • edges[i].length == 3

    • <code>0 <= u<sub>i</sub>, v<sub>i</sub>< n</code>

    • <code>1 <= length<sub>i</sub><= 10<sup>3</sup></code>

    • nums.length == n

    • <code>0 <= numsi<= 5 * 10<sup>4</sup></code>

    • The input is generated such that edges represents a valid tree.

    • Nested Class Summary

      Nested Classes 
      Modifier and Type Class Description
    • Field Summary

      Fields 
      Modifier and Type Field Description
    • Constructor Summary

      Constructors 
      Constructor Description
      Solution()
    • Enum Constant Summary

      Enum Constants 
      Enum Constant Description
    • Method Summary

      Modifier and Type Method Description
      final IntArray longestSpecialPath(Array<IntArray> edges, IntArray nums)
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait