码迷,mamicode.com
首页 > 编程语言 > 详细

Binary Tree Maximum Path Sum leetcode java

时间:2014-08-02 09:50:13      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   java   使用   strong   for   art   

题目

Given a binary tree, find the maximum path sum.

The path may start and end at any node in the tree.

For example:
Given the below binary tree,

       1
      /      2   3

Return 6.

 

题解

 递归求解。

 取当前点和左右边加和,当前点的值中最大的作为本层返回值。并在全局维护一个max。使用数组,因为是引用类型。所以在递归过程中可以保存结果。

代码如下:

 1     public int maxPathSum(TreeNode root) {
 2         int[] max = new int[1];
 3         max[0] = Integer.MIN_VALUE;
 4         findmax(root,max);
 5         return max[0];
 6     }
 7     
 8     public int findmax(TreeNode root, int[] max){
 9         if(root==null)
10             return 0;
11         
12         int left = findmax(root.left,max);
13         int right = findmax(root.right,max);
14         
15         int ans = Math.max(root.val,Math.max(root.val+left, root.val+right));
16         
17         max[0] = Math.max(max[0],Math.max(ans,root.val+left+right));
18         
19         return ans;
20         
21     }

 

Binary Tree Maximum Path Sum leetcode java,布布扣,bubuko.com

Binary Tree Maximum Path Sum leetcode java

标签:style   blog   color   java   使用   strong   for   art   

原文地址:http://www.cnblogs.com/springfor/p/3886411.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!