码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode-124-二叉树中的最大路径和

时间:2020-06-22 02:02:46      阅读:70      评论:0      收藏:0      [点我收藏+]

标签:pre   self   技术   bsp   span   price   class   nod   root   

技术图片

 

 方法:递归 O(n) O(n)

class Solution:
    def __init__(self):
        self.maxSum = float("-inf")

    def maxPathSum(self, root: TreeNode) -> int:
        def maxGain(node):
            if not node:
                return 0

            # 递归计算左右子节点的最大贡献值
            # 只有在最大贡献值大于 0 时,才会选取对应子节点
            leftGain = max(maxGain(node.left), 0)
            rightGain = max(maxGain(node.right), 0)
            
            # 节点的最大路径和取决于该节点的值与该节点的左右子节点的最大贡献值
            priceNewpath = node.val + leftGain + rightGain
            
            # 更新答案
            self.maxSum = max(self.maxSum, priceNewpath)
        
            # 返回节点的最大贡献值
            return node.val + max(leftGain, rightGain)
   
        maxGain(root)
        return self.maxSum

 

leetcode-124-二叉树中的最大路径和

标签:pre   self   技术   bsp   span   price   class   nod   root   

原文地址:https://www.cnblogs.com/oldby/p/13174753.html

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