简洁易懂递归 | 力扣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;
    }
};
相关推荐
吃着火锅x唱着歌1 分钟前
LeetCode 2364.统计坏数对的数目
数据结构·算法·leetcode
qq_336313935 分钟前
java基础-set类集合进阶
java·算法
不知所云,11 分钟前
4. vscode c++ 环境及工程搭建 clangd + mingw
c++·ide·vscode·开发环境·clangd
kyle~14 分钟前
数据结构---堆(Heap)
服务器·开发语言·数据结构·c++
apocelipes14 分钟前
Linux的binfmt_misc机制
linux·c语言·c++·python·golang·linux编程·开发工具和环境
嵌入式老牛15 分钟前
第13章 图像处理之Harris角点检测算法(二)
图像处理·opencv·算法·计算机视觉
渡我白衣16 分钟前
哈希的暴力美学——std::unordered_map 的底层风暴、扩容黑盒与哈希冲突终极博弈
java·c语言·c++·人工智能·深度学习·算法·哈希算法
zl_vslam20 分钟前
SLAM中的非线性优-3D图优化之相对位姿Between Factor(六)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
qq_4335545428 分钟前
C++ 最大子段和(动态规划)
开发语言·c++·动态规划
lijiatu1008629 分钟前
[C++] lock_guard、unique_lock与条件变量wait()函数
开发语言·c++