简洁易懂递归 | 力扣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;
    }
};
相关推荐
优雅的潮叭11 分钟前
c++ 学习笔记之 chrono库
c++·笔记·学习
星火开发设计21 分钟前
C++ 数组:一维数组的定义、遍历与常见操作
java·开发语言·数据结构·c++·学习·数组·知识
月挽清风44 分钟前
代码随想录第七天:
数据结构·c++·算法
小O的算法实验室1 小时前
2026年AEI SCI1区TOP,基于改进 IRRT*-D* 算法的森林火灾救援场景下直升机轨迹规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小郭团队1 小时前
2_1_七段式SVPWM (经典算法)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·硬件架构·arm·dsp开发
充值修改昵称2 小时前
数据结构基础:从二叉树到多叉树数据结构进阶
数据结构·python·算法
Deepoch2 小时前
Deepoc数学大模型:发动机行业的算法引擎
人工智能·算法·机器人·发动机·deepoc·发动机行业
点云SLAM2 小时前
C++内存泄漏检测之Windows 专用工具(CRT Debug、Dr.Memory)和Linux 专业工具(ASan 、heaptrack)
linux·c++·windows·asan·dr.memory·c++内存泄漏检测·c++内存管理
浅念-2 小时前
C语言小知识——指针(3)
c语言·开发语言·c++·经验分享·笔记·学习·算法
Hcoco_me3 小时前
大模型面试题84:是否了解 OpenAI 提出的Clip,它和SigLip有什么区别?为什么SigLip效果更好?
人工智能·算法·机器学习·chatgpt·机器人