news 2026/6/15 16:47:49

算法:二叉树最大路径和

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法:二叉树最大路径和

核心解题思路

要理解这个算法,你需要明白二叉树中的任何一个节点在计算路径时,其实扮演了两个不同的角色

1. 对“上级”(父节点)的角色:只能提供一条腿

当一个节点(比如 root)向它的父节点汇报工作时,它不能把“左+根+右”这个像拱桥一样的路径汇报上去。因为路径不能分叉,一条路径要想继续向上延伸,只能选择左边或者右边的一条路

汇报值= root->val + max(左子树能提供的最大单边路径, 右子树能提供的最大单边路径)。

2. 对“全局答案”的角色:可以是路径的最高点(拐点)

一条路径可以在当前节点“拐弯”。也就是说,路径可以是 左子树 -> 当前节点 -> 右子树。

当前节点为拐点的最大路径和= 左子树最大贡献 + 右子树最大贡献 + root->val。

我们需要每遍历到一个节点,就计算一下以它为“拐点”的路径和是否比当前的全局最大值 ans 还要大。如果是,就更新 ans。

完整代码:

class Solution { public: int maxPathSum(TreeNode* root) { int ans = INT_MIN; // 初始化为一个最小值,防止题目全是负数节点时出错 dfs(root, ans); // 开始递归 return ans; // 返回最终找到的全局最大路径和 } // 注意这里 ans 是引用传递 (int &ans),这样递归中修改的都是同一个变量 int dfs(TreeNode *root, int &ans) { // 1. 递归终止条件(Base Case) // 如果节点为空,它对路径的贡献就是 0 if (root == nullptr) return 0; // 2. 递归计算左右子树的“最大贡献值” // 核心逻辑:max(0, ...) 是精华所在! // 如果子树计算出的路径和是负数(比如 -10),那我们不如不选那条路(即贡献为 0)。 // 这相当于“剪枝”,把负贡献的尾巴剪掉。 int left = max(0, dfs(root->left, ans)); int right = max(0, dfs(root->right, ans)); // 3. 计算“单边最大路径”(用于返回给父节点) // temp 代表:如果父节点想连我,我能提供的最大值。 // 我只能带上我左右孩子中较大的那一个(或者都不带,如果都是0)。 int temp = max(left, right) + root->val; // 4. 更新全局最大值(ans) // 这里原作者写了两行更新,其实逻辑涵盖了两种情况: // 第一行:更新单边路径的情况(比如路径只到当前节点为止,或者只连一边) ans = max(ans, temp); // 第二行:更新“拱桥”情况(最关键的一步) // 路径形态:左孩子 -> 当前节点 -> 右孩子 // 这代表路径在当前节点这里“拐弯”了,不再向父节点延伸。 ans = max(ans, left + right + root->val); // 5. 返回值 // 注意!这里必须返回 temp。 // 因为 dfs 函数的定义是“返回该节点能给父节点提供的最大单边路径”。 // 你不能返回“左+根+右”,因为那是一条死路(两头都堵住了),不能再连父节点了。 return temp; } };

输入: root = [1, 2, 3]

步骤演示:

  1. 处理节点 2 (左子叶):
    • left, right 都是 0 (因为无子节点)。
    • temp (汇报给父节点) = $0 + 0 + 2 = 2$。
    • 更新 ans:此时 ans 可能是 2 (视初始化和遍历顺序而定)。
    • 返回 2
  2. 处理节点 3 (右子叶):
    • left, right 都是 0。
    • temp (汇报给父节点) = $0 + 0 + 3 = 3$。
    • 更新 ans:ans 更新为 3。
    • 返回 3
  3. 处理节点 1 (根节点):
    • left = 2 (来自节点 2 的返回值)。
    • right = 3 (来自节点 3 的返回值)。
    • 计算拱桥路径 (拐点路径):$left + right + root->val = 2 + 3 + 1 = 6$。
    • 更新 ans:ans 变为6
    • 计算返回值 (temp):max(2, 3) + 1 = 4 (这意味着如果 1 还有父节点,它会汇报 4)。

最终结果 ans = 6

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 16:39:11

[LCD Monitor] 液晶显示器超频设置方法

文章目录[LCD Monitor] 液晶显示器超频设置方法请检查您的显卡和液晶显示器是否都支持超频安装最新版显卡驱动调整显示器设置:关闭 Adaptive-Sync (Free-Sync) 或 G-Sync 功能,使分辨率固定为默认设置。 打开 OSD -> 超频 如果要启用此功能&#xff0…

作者头像 李华
网站建设 2026/6/15 14:27:03

274852785

7852785

作者头像 李华
网站建设 2026/6/15 10:23:58

A_B测试在大数据领域的长期效果评估

A/B测试在大数据领域的长期效果评估:从“短期胜负”到“长期可持续” 引言:你可能正在为“短期正确”付出长期代价 去年,我遇到一位做电商推荐算法的朋友,他的困惑让我印象深刻: 为了提升商品点击率,他们做…

作者头像 李华
网站建设 2026/6/15 11:18:07

2000-2024年地级市国内旅游收入、旅游外汇收入、旅游总收入数据

2000-2024年 上市公司-财务重述数据 数据介绍:参考马晨等(2016的做法,使用财务重述公告中所更正年报对应的年度作为财务重述的年度,若企业年报中发生财务重述取1,否则取0。财务重述是指上市公司对以前年度财务报表中的会计差错进…

作者头像 李华
网站建设 2026/6/15 11:25:36

基于Spring Boot的运动服装销售系统的设计与实现

🍅 作者主页:Selina .a 🍅 简介:Java领域优质创作者🏆、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行交流合作。 主要内容:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据…

作者头像 李华