当前位置:首页 > 牛客 > 牛客125题解:二叉树最大路径和的动态规划解法

牛客125题解:二叉树最大路径和的动态规划解法

2个月前 (09-24)

牛客125题解:二叉树最大路径和的动态规划解法 牛客题解 二叉树 动态规划 后序遍历 递归 树结构 DFS 深度优先搜索 深搜 第1张

一、题目解读

牛客125题要求求解一棵二叉树中节点之间的最大路径和。路径定义为任意两个节点之间的连通路径(无需经过根节点),节点值可正可负。核心在于找到包含节点值之和最大的路径,需考虑子贡献与全局最优解的权衡。

二、解题思路

1. 后序遍历:通过递归遍历二叉树,自底向上计算每个节点的贡献;

2. 动态规划:维护两个值:

○ 当前节点为路径起点的最大路径和(需包含左右子树中较大的贡献);

○ 全局最大路径和(更新所有可能路径中的最大值);

3. 处理负数:若子树贡献为负,则舍弃该子树,避免影响整体路径和。

三、解题步骤

1. 初始化:全局变量max_sum设为INT_MIN,确保首次更新时任何正数均有效;

2. 递归函数DFS

○ 若节点为空,返回0;

○ 递归计算左右子树的最大贡献值left、right,若为负则置为0(舍弃);

○ 计算当前节点作为路径转折点时的路径和:node->val + left + right;

○ 更新全局最大路径和max_sum;

○ 返回当前节点的最大贡献值:node->val + max(left, right)(仅保留单侧最大贡献)。

3. 主函数调用:通过dfs(root)启动递归,最终返回max_sum作为结果。

四、代码与注释

class Solution {
public:
    int maxPathSum(TreeNode* root) {
        max_sum = INT_MIN; // 初始化为最小整数值
        dfs(root);
        return max_sum;
    }
private:
    int max_sum;
    // 后序遍历计算最大路径和
    int dfs(TreeNode* node) {
        if (!node) return 0;
        // 递归计算左右子树的最大贡献值(负数则舍弃)
        int left = max(dfs(node->left), 0);
        int right = max(dfs(node->right), 0);
        // 当前节点作为路径转折点时的路径和
        int current_sum = node->val + left + right;
        max_sum = max(max_sum, current_sum);
        // 返回当前节点的最大贡献值(只能选择左右子树中的一个)
        return node->val + max(left, right);
    }
};

五、总结

本解法通过动态规划与后序遍历的结合,巧妙解决二叉树最大路径和问题。关键在于“自底向上”计算节点贡献,并灵活处理负数情况避免路径恶化。时间复杂度O(n)(遍历所有节点),空间复杂度O(n)(递归空间)。适用于需要求解树中任意路径最值的场景,体现了算法设计与问题转化的精髓。


原创内容 转载请注明出处

分享给朋友:

相关文章

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

题目重解我们面对一个经典背包问题的变体:给定n个物品,每个物品有重量w和价值v,背包容量为V。需要回答两个问题:1) 普通情况下能获得的最大价值;2) 必须恰好装满背包时的最大价值(若无法装满则输出0...

NOIP 2008火柴棒等式题解(C++代码实现)  动态规划与枚举算法详解

NOIP 2008火柴棒等式题解(C++代码实现) 动态规划与枚举算法详解

一、题目解读火柴棒等式问题(NOIP 2008,洛谷P1149)要求使用给定数量的火柴棒,构造形如 A + B = C 的等式,其中A、B、C均为整数,且火柴棒总数恰好等于输入值。需统计符合条件的等式...

CSP-J 2019公交换乘题解析:基于队列优化的动态规划代码详解

CSP-J 2019公交换乘题解析:基于队列优化的动态规划代码详解

一、题目解读CSP-J 2019年的“公交换乘”题目(洛谷P5661)要求模拟地铁与公交交替出行的费用计算。题目核心在于地铁消费会产生优惠券,而公交可在45分钟内使用优惠券抵扣车费。需要处理n条出行记...

牛客13279题解:利用递归与深度优先搜索计算树的最大高度(附完整代码)

牛客13279题解:利用递归与深度优先搜索计算树的最大高度(附完整代码)

一、题目解读牛客13279题要求计算给定树的最大高度。题目输入一棵以邻接表形式表示的树(节点从0开始编号),需要输出从根节点到最深叶节点的最长路径长度。树的结构由n个节点和n-1条边构成,保证为连通无...

洛谷2789题解:直线交点数的递归求解与优化(附代码详解)

洛谷2789题解:直线交点数的递归求解与优化(附代码详解)

一、题目解读洛谷2789题要求计算n条直线在平面上两两相交时产生的不同交点数量。题目强调“不同”交点,需排除重复情况。解题关键在于如何高效枚举所有可能的交点组合,并避免重复计数。二、解题思路参考代码采...

2022 CSP-J 上升点序(洛谷P8816)解题报告:动态规划求解最长上升序列

2022 CSP-J 上升点序(洛谷P8816)解题报告:动态规划求解最长上升序列

一、题目解读2022年CSP-J题目“上升点序”(洛谷P8816)要求给定一个平面点集,每个点的坐标(x,y)均为整数。题目需要构造一个最长的上升序列,序列中相邻点的坐标满足x和y均严格递增。允许使用...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。