給的多叉樹, 找這顆樹裏面最長的路徑長度
解法就是在子樹裏面找最大的兩個(或一個,若是隻有一個子樹的話)高度加起來。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 }