LeetCode104.二叉树的最大深度

题目

给定一个二叉树 root ,返回其最大深度。

二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。

示例

c 复制代码
输入:root = [3,9,20,null,null,15,7]
输出:3

思路

计算二叉树的最大深度通常可以使用 递归 来实现。我们可以从根节点开始,递归地计算每个子树的深度,然后取左右子树中深度较大的值加1作为当前节点的深度。

具体的思路如下:

  • 如果二叉树为空,则深度为 0。
  • 否则,计算左子树的深度和右子树的深度。
  • 取左右子树中深度较大的值加1作为当前节点的深度。
  • 递归计算左右子树的深度并返回左右子树深度的最大值加1。

Code

c 复制代码
class Solution {
public:
    int maxDepth(TreeNode* root) {
        // 如果根节点为空,返回深度为 0
        if (root == nullptr) {
            return 0;
        }
        
        // 递归计算左子树和右子树的最大深度
        int leftDepth = maxDepth(root->left);
        int rightDepth = maxDepth(root->right);
        
        // 返回左右子树深度的最大值加上根节点的深度 1
        return max(leftDepth, rightDepth) + 1;
    }
};
相关推荐
rit84324999 分钟前
MATLAB近红外光谱预处理:平滑与求导(MSV方法)
数据结构·算法·matlab
蚂蚁数据AntData14 分钟前
从ChatBI到业务记忆:重新定义数据智能的生产力边界
大数据·网络·数据库·人工智能·算法
_日拱一卒15 分钟前
LeetCode:22括号生成
算法·leetcode·职场和发展
cfm_291416 分钟前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
触底反弹23 分钟前
从 JS 引擎执行原理理解数据类型:栈内存、堆内存与作用域
javascript·数据结构·面试
郝学胜_神的一滴25 分钟前
干货版《算法导论》09:让哈希表稳如泰山的终极解法
数据结构·算法
CC数学建模31 分钟前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题C题:创业社区规划与资源配置优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
徐小夕33 分钟前
我们放弃了单Agent方案:HiCAD 3.0 用 Harness 做多Agent编排,把3D建模的准确率提升了30%
前端·算法·github
洛水水37 分钟前
【力扣100题】88.多数元素
数据结构·算法·leetcode
alwaysrun41 分钟前
C++之常量体系const
c++·后端·程序员