力扣 hot100 Day52

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

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

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

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

cpp 复制代码
//自己写的
class Solution {
public:
    int maxpasssum(TreeNode* root,int& maxtmp)
    {
        if(!root) return 0;
        int leftmaxsum = max(maxpasssum(root->left,maxtmp),0);
        int rightmaxsum = max(maxpasssum(root->right,maxtmp),0);
        maxtmp = max(maxtmp,leftmaxsum+rightmaxsum+root->val);
        return root->val+max(leftmaxsum,rightmaxsum);
    }
    int maxPathSum(TreeNode* root) {
        int maxtmp = INT_MIN;
        maxpasssum(root,maxtmp);
        return maxtmp;        
    }
};

逻辑有点像求二叉树的最大深度,都是需要在递归过程中间进行判断再回溯

本题需要考虑的是,对于递归到的根节点来说,最大路径和可能并不经过该节点,所以需要引入一个maxtmp进行存储。

这里maxpasssum返回值含义是,目前经过该节点的最大单向路径和(不横跨左右子树),left/rightmaxsum则为其左右子树返回的对应值与0的最大值(返回值可能小于0,此时取零相当于不考虑加上这条分支了)

由此可以递推对于任意节点,新出现的可能最大路径和为leftmaxsum+rightmaxsum+root->val,实时比较更新就可以得到最终结果了。

相关推荐
Aurora_wmroy1 分钟前
算法竞赛备赛——【图论】求最短路径——Bellman-Ford & SPFA
数据结构·c++·算法·蓝桥杯·图论
阑梦清川26 分钟前
算法竞赛小白进阶之路----洛谷网站关于链表的两个题目
算法
刚入坑的新人编程1 小时前
暑假算法训练.6
数据结构·c++·算法·哈希算法
别摸我的婴儿肥1 小时前
从0开始LLM-注意力机制-4
人工智能·python·算法
Mr.小海2 小时前
金融大模型与AI在金融业务中的应用调研报告(2025年)
人工智能·算法·机器学习·chatgpt·金融·gpt-3·文心一言
小刘|2 小时前
分布式面试点
分布式·面试·职场和发展
Das13 小时前
【初识数据结构】CS61B 中的堆以及堆排序算法
数据结构·算法·排序算法
思绪漂移4 小时前
计算机视觉领域的AI算法总结——目标检测
人工智能·算法·目标检测·计算机视觉
HalvmånEver4 小时前
希尔排序详解及代码讲解
c语言·数据结构·算法·排序算法
qqxhb4 小时前
零基础数据结构与算法——第五章:高级算法-回溯算法&子集&全排列问题
算法·回溯算法·全排列·n皇后·子集