leetcode ho100 124. 二叉树中的最大路径和 hard


python 复制代码
	   a (root)
  	 /    \
    b      c

对于一个节点node,有3种情况:

  1. node是最大路径的转折点(U型路径):b+a+c
  2. node是最大路径的传递者(单边向上):路径为 a+ba + ba+b 或 a+ca + ca+c。把这一段送给父节点,父节点可以继续往上连。:b+a+a的父节点
  3. node是最大路径的独立点(or null 节点):如果左右子树全是负数,你可能只选你自己 aaa,并把它送给父节点。
  4. node是最大路径的旁观者:最大路径完全在你的左子树或右子树内部产生,根本不经过node。

"能向上汇报的贡献值"和"当前形成的完整路径和"。

  • 计算:当前形成的完整路径和(递归),更新最大值变量
  • 返回:能向上汇报的贡献值
python 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def maxPathSum(self, root: Optional[TreeNode]) -> int:  # 返回root的最大路径

        # 全局变量记录遍历过程中产生的最大值。
        self.max_sum = float('-inf')   # 子函数需要调的父函数的变量self.

        def dfs(node):
            if not node:  # 没有节点,和为 0
                return 0

            # 1. 向下递归:子树贡献是负数,不选
            left_gain = max(dfs(node.left), 0)  #  左子节点的最大路径
            right_gain = max(dfs(node.right), 0)  #  左子节点的最大路径

            # 2.  "拐弯"的路径: 左边贡献 + 当前节点 + 右边贡献 
            # 如果左右子树贡献为0,自然就是"单边"or"就node自己"
            current_path_sum = node.val + left_gain + right_gain

            # 更新全局最大值
            self.max_sum = max(self.max_sum, current_path_sum)

            # 3. 向上回溯:返回给父节点
            # node作为父节点的子节点,(node向下只能单边)
            return node.val + max(left_gain, right_gain)

        dfs(root)  # 在dfs中更新全局变量
        return self.max_sum

        

时间复杂度:O(n),其中 n 为二叉树的节点个数。

空间复杂度:O(n)。最坏情况下,二叉树退化成一条链,递归需要 O(n) 的栈空间。

相关推荐
小欣加油18 小时前
leetcode239 滑动窗口最大值
数据结构·c++·算法·leetcode·哈希算法
吃着火锅x唱着歌18 小时前
LeetCode 3829.设计共享出行系统
算法·leetcode·职场和发展
菜菜的顾清寒19 小时前
力扣HOT100(52)动态规划 - 最长递增子序列
算法·leetcode·动态规划
x_xbx19 小时前
LeetCode:20. 有效的括号
算法·leetcode·职场和发展
8Qi820 小时前
LeetCode 295:数据流的中位数(Median Finder)—— Java 题解 ✅
java·算法·leetcode·优先队列··中位数
练习时长一年1 天前
LeetCode热题100(二叉树的最大路径和)
算法·leetcode·职场和发展
啦哈拉哈1 天前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
z200509302 天前
今日算法(回溯全排列)
c++·算法·leetcode
小欣加油2 天前
leetcode3633 最早完成陆地和水上游乐设施的时间I
数据结构·c++·算法·leetcode
memcpy02 天前
LeetCode 2657. 找到两个数组的前缀公共数组【集合,位运算】中等
算法·leetcode·职场和发展