简洁易懂递归 | 力扣124.二叉树中的最大路径和

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

文章目录

解题方法

递归实现

最大路径和只会出现在以下3种情况:

  1. 只取当前节点
  2. 取当前节点和最大的一个孩子
  3. 取两个孩子,并以当前节点为根节点(这种无需return给上一层)

递归时,每次都记录下上面3种情况的最大值即可

复杂度

时间复杂度:

添加时间复杂度, 示例: O ( n ) O(n) O(n)

空间复杂度:

添加空间复杂度, 示例: O ( 1 ) O(1) O(1)

Code

cpp 复制代码
class Solution {
public:
    int res;
    int dp(TreeNode* root){// 递归:包含当前节点的路径最大值
        if(!root)return -10005;
        int leftMax = dp(root->left);
        int rightMax = dp(root->right);
        int childMax = max(leftMax,rightMax);
        // 最大路径和只会出现在以下3种情况
        int a = root->val; // 只取当前节点
        int b = root->val+childMax; // 取当前节点和最大的一个孩子
        int c = root->val+leftMax+rightMax; // 取两个孩子,并以当前节点为根节点(这种无需return给上一层)
        // 每次都记录下上面3种情况的最大值
        int tmp = max(max(a,b),c);
        if(tmp > res)res=tmp;
        
        return max(a,b);// 返回给上一层节点用来做路径的一部分,因为c这种情况已经是一种路径了,就不用返回。
    }
    int maxPathSum(TreeNode* root) {
        res=-10005;
        dp(root);
        return res;
    }
};
相关推荐
踩坑记录19 分钟前
leetcode hot100 3.无重复字符的最长子串 medium 滑动窗口(双指针)
python·leetcode
Z1Jxxx22 分钟前
01序列01序列
开发语言·c++·算法
坚定学代码1 小时前
基于观察者模式的ISO C++信号槽实现
开发语言·c++·观察者模式·ai
汽车仪器仪表相关领域2 小时前
全自动化精准检测,赋能高效年检——NHD-6108全自动远、近光检测仪项目实战分享
大数据·人工智能·功能测试·算法·安全·自动化·压力测试
ha20428941942 小时前
Linux操作系统学习记录之---TcpSocket
linux·网络·c++·学习
Doro再努力2 小时前
【数据结构08】队列实现及练习
数据结构·算法
AI视觉网奇3 小时前
ue5 插件 WebSocket
c++·ue5
左直拳3 小时前
将c++程序部署到docker
开发语言·c++·docker
恒者走天下3 小时前
AI智能体通讯项目(底层AI通讯协议实现)
c++
英雄各有见3 小时前
Chapter 5.1.1: 编写你的第一个GPU kernel——Cuda Basics
c++·gpu·cuda·hpc