首页 > 其他 > 详细

Binary Tree Maximum Path Sum

时间:2016-04-19 22:54:32      阅读:456      评论:0      收藏:0      [点我收藏+]

从底向上

返回值是当前连续的最大值

m是当前所有的最大值

 

class Solution {
public:
    int m=INT_MIN;
    int maxPath(TreeNode* root)
    {
     if(root==NULL)
        return 0;
        int value=0,lmax=0,rmax=0;
        value=root->val;
        if(root->left)
        {
            lmax=maxPath(root->left);
            if(lmax>0)
            value+=lmax;
        }
        if(root->right)
        {
            rmax=maxPath(root->right);
            if(rmax>0)
            value+=rmax;
        }
        if(value>m)m=value;
        return max(lmax,rmax)>0?max(lmax,rmax)+root->val:root->val;
        }
    int maxPathSum(TreeNode* root) {
        if(root==NULL) 
        return 0;
        maxPath(root);
        return m;
        
    }
};

 

Binary Tree Maximum Path Sum

原文:http://www.cnblogs.com/daocaorenblog/p/5410496.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!