FB面經Prepare: Find Longest Path in a Multi-Tree

給的多叉樹, 找這顆樹裏面最長的路徑長度 

解法就是在子樹裏面找最大的兩個(或一個,若是隻有一個子樹的話)高度加起來。java

對於每個treenode, 維護它的最高的高度和第二高的高度,通過該點的最大路徑就是:  最高高度+第二高高度,而後return 最高高度node

 

 1 package fbPractise;
 2 
 3 import java.util.*;
 4 
 5 class TreeNode {
 6     int val;
 7     List<TreeNode> children;
 8     public TreeNode(int value) {
 9         this.val = value;
10         this.children = new ArrayList<TreeNode>();
11     }
12 }
13 
14 
15 public class LongestPathInTree {
16     static int maxLen = 0;
17     
18     public static int findLongestPath(TreeNode node) {
19         findMaxPath(node);
20         return maxLen;
21     }
22     
23     public static int findMaxPath(TreeNode node) {
24         if (node == null) return 0;
25         int heightest1 = 0;
26         int heightest2 = 0;
27         
28         for (TreeNode child : node.children) {
29             int childHeight = findMaxPath(child);
30             
31             if (childHeight > heightest1) {
32                 heightest2 = heightest1;
33                 heightest1 = childHeight;
34             }
35             else if (childHeight > heightest2) {
36                 heightest2 = childHeight;
37             }
38         }
39         maxLen = Math.max(maxLen, 1 + heightest1 + heightest2);
40         return 1 + heightest1;
41     }
42     
43     
44     public static void main(String[] args) {
45         TreeNode node1 = new TreeNode(1);
46         TreeNode node2 = new TreeNode(2);
47         TreeNode node3 = new TreeNode(3);
48         TreeNode node4 = new TreeNode(4);
49         TreeNode node5 = new TreeNode(5);
50         TreeNode node6 = new TreeNode(6);
51         node1.children.add(node2);
52         node1.children.add(node3);
53         node2.children.add(node4);
54         node2.children.add(node5);
55         node5.children.add(node6);
56         
57         int res = findLongestPath(node1);
58         System.out.println(res);
59     }
60     
61     
62 }
相關文章
相關標籤/搜索