博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[leetcode] Binary Tree Maximum Path Sum
阅读量:6568 次
发布时间:2019-06-24

本文共 1247 字,大约阅读时间需要 4 分钟。

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.

给定一颗二叉树,找到最大的路径和,起点和重点可以是树的任意节点。

对于每一个节点,有三种情况,

最大值是以下几种情况的最大值:

1. 左子树的最大值;

2. 右子树的最大值;

3. 部分path在左子树,部分path在右子树,经过root;

1与2在递归中计算,为返回值;

3的话需要维护止于root点的最大值,这里用myMax表示(只有一边,止于root)

myMax,可以先求左右myMax的最大值,如果这个值是正数,那么可以把root也算上,不然就直接是root了。

返回值至少是myMax,然后再和左右子树的返回值比,最后和经过root,包含左右子树的情况相比。注意的是排除掉左右子树为空的情况。

代码如下:

1 class Solution { 2 public: 3     int mPS(TreeNode * root, int & myMax) 4     { 5         if( root == NULL ) 6         { 7             return 0; 8         } 9         int left = mPS(root->left, myMax);10         int right = mPS(root->right, myMax);11         int res = root->val;12         if( left > 0 )13         {14             res += left;15         }16         if( right > 0 )17         {18             res += right;19         }20         myMax = max(res, myMax);21         return max(root->val, max(root->val+left,root->val+right));  22     }23     int maxPathSum(TreeNode *root) 24     {25         int myMax = root->val;26         int val =  mPS(root, myMax);27         return max(myMax, val);28     }29 };

 

转载于:https://www.cnblogs.com/jostree/p/3713128.html

你可能感兴趣的文章
dojo 学习笔记之dojo.query - query(id) 与query(class)的差别
查看>>
Java基础加强总结(三)——代理(Proxy)
查看>>
一步一步写算法(之hash表)
查看>>
C99规范
查看>>
BZOJ3799 : 字符串重组
查看>>
数据持久化的复习
查看>>
Util应用程序框架公共操作类(八):Lambda表达式公共操作类(二)
查看>>
thinkphp查询
查看>>
iOS开发-Protocol协议及委托代理(Delegate)传值
查看>>
【BZOJ】1105: [POI2007]石头花园SKA
查看>>
MapReduce原理与设计思想
查看>>
Theano学习笔记(三)——图结构
查看>>
UVa - 11400 - Lighting System Design
查看>>
Oracle 11g 客户端使用
查看>>
luvit 被忽视的lua 高性能框架(仿nodejs)
查看>>
也许每个农村出来的码农都有个田园梦
查看>>
J2EE的13种核心技术
查看>>
Express.js 中的 Sessions 如何工作?(译)
查看>>
Web自动化之Headless Chrome概览
查看>>
【133天】尚学堂高淇Java300集视频精华笔记(71-72)
查看>>