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;
    }
};
相关推荐
dapeng287010 小时前
分布式系统容错设计
开发语言·c++·算法
qq_4176950510 小时前
代码热修复技术
开发语言·c++·算法
C++ 老炮儿的技术栈16 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
hz_zhangrl16 小时前
CCF-GESP 等级考试 2026年3月认证C++一级真题解析
开发语言·c++·gesp·gesp2026年3月·gespc++一级
Liu6288817 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
AI科技星17 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
参.商.17 小时前
【Day41】143. 重排链表
leetcode·golang
波特率11520017 小时前
const关键字与函数的重载
开发语言·c++·函数重载
条tiao条18 小时前
KMP 算法详解:告别暴力匹配,让字符串匹配 “永不回头”
开发语言·算法
干啥啥不行,秃头第一名18 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法