简洁易懂递归 | 力扣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;
    }
};
相关推荐
数据皮皮侠3 分钟前
1095 《中国城市统计年鉴》面板数据整理
大数据·数据库·人工智能·算法·制造
寒月小酒7 分钟前
3.26 OJ
数据结构·算法
福楠8 分钟前
现代C++ | 智能指针
c语言·开发语言·c++
汉克老师14 分钟前
GESP5级C++考试语法知识(十二、递归算法(二))
c++·算法·记忆化搜索·时间复杂度·递归算法·gesp5级·gesp五级
lcreek14 分钟前
计算机网络与图算法:从理论到实践
算法·
旺仔.29115 分钟前
顺序容器:Array 数组 详解
c++
sinat_2554878116 分钟前
JSON·学习笔记
java·开发语言·笔记·算法
Yupureki23 分钟前
《算法竞赛从入门到国奖》算法基础:动态规划-基础线性dp
c语言·开发语言·算法·动态规划
qq_3928079529 分钟前
Qt 注册 C++ 给 QML 调用的几种方式
数据库·c++·qt
Roselind_Yi33 分钟前
从线性回归实战到Python依赖安装踩坑:我的机器学习入门排雷记
笔记·python·算法·机器学习·回归·线性回归·学习方法