news 2026/4/18 8:35:54

day168—递归—二叉树的最大路径和(LeetCode-124)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day168—递归—二叉树的最大路径和(LeetCode-124)

题目描述

二叉树中的路径被定义为一条节点序列,序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中至多出现一次。该路径至少包含一个节点,且不一定经过根节点。

路径和是路径中各节点值的总和。

给你一个二叉树的根节点root,返回其最大路径和

示例 1:

输入:root = [1,2,3]输出:6解释:最优路径是 2 -> 1 -> 3 ,路径和为 2 + 1 + 3 = 6

示例 2:

输入:root = [-10,9,20,null,null,15,7]输出:42解释:最优路径是 15 -> 20 -> 7 ,路径和为 15 + 20 + 7 = 42

提示:

  • 树中节点数目范围是[1, 3 * 104]
  • -1000 <= Node.val <= 1000

解决方案:

这段代码是基于后序遍历(DFS)求解二叉树最大路径和的经典最优实现,核心思路是通过递归同时完成两个关键任务:计算节点向下延伸的有效路径和、统计以每个节点为 “拐点” 的完整路径和,最终找到整棵树的最大路径和。

核心逻辑

  1. 核心定义

    • ans:全局变量(初始化为极小值-0xFFFF),用于记录遍历过程中找到的最大路径和,覆盖所有可能的路径场景;
    • dfs(node):递归函数,核心作用有两个:① 返回node为起点,向下延伸(仅能选左 / 右子树其一)的有效路径和(有效指路径和非负,负路径无贡献);② 递归过程中计算以node为 “拐点” 的完整路径和,并更新全局最大值ans
  2. 递归边界:若node为空(!node),返回 0—— 空节点对路径和无任何贡献,直接返回 0。

  3. 后序遍历核心逻辑

    • 先递归计算左子树的向下有效路径和l_val = dfs(node->left)
    • 再递归计算右子树的向下有效路径和r_val = dfs(node->right)
    • 关键更新:以当前节点为 “拐点” 的完整路径和 =l_val + r_val + node->val(左子树延伸路径 + 右子树延伸路径 + 当前节点值),用该值更新ans(确保不遗漏所有可能的路径);
    • 结果返回:max(0, max(l_val, r_val) + node->val)—— 仅返回向下延伸的最优路径和,且通过max(0, ...)过滤负贡献(若路径和为负,说明该路径无价值,直接返回 0 放弃)。
  4. 主函数逻辑:调用dfs(root)触发整棵树的后序遍历,遍历完成后ans即为整棵树的最大路径和,直接返回即可。

关键特点

  • 时间效率 O (n):每个节点仅被递归访问一次,无重复计算,是二叉树遍历的最优时间复杂度;
  • 空间效率 O (h):递归栈深度等于树的高度h(平衡树h=logn,链表状树h=n),无额外空间开销;
  • 逻辑精准
    • 用 “拐点路径和” 覆盖所有可能的路径形态(如左子树→当前节点→右子树、单节点、单侧子树延伸等);
    • max(0, ...)过滤负贡献路径,避免无效路径拉低整体和(例如节点值全为负时,会选择值最大的单个节点);
  • 边界适配:初始值-0xFFFF能覆盖 “所有节点值为负” 的极端场景,确保不会遗漏有效路径。

总结

  1. 核心思路:后序遍历中,将 “向下延伸的路径和”(供父节点使用)与 “拐点完整路径和”(更新全局最大值)拆分处理,兼顾递归传递性和结果完整性;
  2. 关键设计:max(0, ...)过滤负贡献、“拐点路径和更新 ans” 是解决该问题的两大核心;
  3. 功能效果:能正确处理所有场景(含全负节点、单节点、平衡树 / 链表树等),是该问题的工程级最优解法。

函数源码:

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: int ans=-0xFFFF; int dfs(TreeNode* node){ if(!node) return 0; int l_val=dfs(node->left); int r_val=dfs(node->right); ans=max(ans,l_val+r_val+node->val); return max(0,max(l_val,r_val)+node->val); } int maxPathSum(TreeNode* root) { dfs(root); return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 17:39:06

计算机Java毕设实战-基于SpringBoot在线小说阅读平台基于springboot的小说阅读平台【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/17 8:23:39

字节序及IP地址转换

文章目录字节序检测主机字节序字节序转换函数函数原型示例IP地址字符串与二进制转换传统转换函数&#xff08;IPv4专用&#xff09;现代转换函数&#xff08;支持IPv4/IPv6&#xff09;线程安全的转换字节序 定义&#xff1a;多字节数据在内存中存储或网络传输时各字节的顺序两…

作者头像 李华
网站建设 2026/4/18 0:30:12

【AI经典论文解读】《High-Resolution Image Synthesis with Latent Diffusion Models(基于潜在扩散模型的高分辨率图像合成)》论文深度解读

从像素炼狱到“潜空间”捷径&#xff1a;LDM如何引爆AI绘画革命并实现算力民主化 感知压缩与语义生成的完美解耦 在2021年前后&#xff0c;扩散模型虽然已经证明了其在图像生成质量上能超越GAN&#xff0c;但“昂贵”是它撕不掉的标签。由于需要在高维度的像素空间&#xff0…

作者头像 李华
网站建设 2026/4/18 0:30:54

深度测评专科生必用8款一键生成论文工具:开题报告文献综述全攻略

深度测评专科生必用8款一键生成论文工具&#xff1a;开题报告文献综述全攻略 为什么需要这份专科生专属论文工具测评&#xff1f; 随着学术写作需求的不断增长&#xff0c;越来越多的专科生开始依赖AI写作工具来提升论文撰写效率。然而&#xff0c;面对市场上琳琅满目的工具&am…

作者头像 李华
网站建设 2026/4/18 0:27:18

学术写作的第一步不再复杂,AI工具助你高效完善开题报告模板

AI开题报告工具对比速览 工具名称 核心功能 生成速度 适用场景 独特优势 AIbiye 全流程论文辅助 3-5分钟 从开题到定稿 深度学术逻辑构建 AIcheck 精准开题生成 2-3分钟 快速产出初稿 国内院校模板库 AskPaper 文献综述辅助 实时响应 研究现状分析 海量文献…

作者头像 李华