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) 的栈空间。

相关推荐
洛水水7 小时前
【力扣100题】18.随机链表的复制
算法·leetcode·链表
he___H13 小时前
接雨水----解
leetcode
洛水水15 小时前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
Tisfy18 小时前
LeetCode 2553.分割数组中数字的数位:模拟(maybe+翻转)——java也O(1)
java·数学·算法·leetcode·题解·模拟·取模
Controller-Inversion18 小时前
42. 接雨水
数据结构·算法·leetcode
Controller-Inversion18 小时前
33. 搜索旋转排序数组
数据结构·算法·leetcode
驼同学.18 小时前
【求职季】LeetCode Hot 100 渐进式扫盲手册(Python版)
python·算法·leetcode
宵时待雨19 小时前
优选算法专题6:模拟
数据结构·c++·算法·leetcode·职场和发展
Liangwei Lin19 小时前
LeetCode 35. 搜索插入位置
数据结构·算法·leetcode
洛水水20 小时前
【力扣100题】22. 矩阵置零
算法·leetcode·矩阵