当前位置: 首页 > news >正文

LeetCode hot 力扣热题100 二叉树的最大深度

class Solution {
public:int maxDepth(TreeNode* root) {if (root == nullptr) {return 0;}int l_depth = maxDepth(root->left);int r_depth = maxDepth(root->right);return max(l_depth, r_depth) + 1;}
};

代码作用

该函数通过递归计算二叉树的最大深度(从根节点到叶子节点的最长路径上的节点数)。

运行步骤示例

假设有以下二叉树:

        1

       / \

      2   3

     / \

    4   5

函数调用顺序

1. 初始调用:

maxDepth(root) // root 节点值为 1

2. 检查 root 是否为 nullptr:

• root 为节点 1,非空,继续。

3. 递归计算左子树深度:

l_depth = maxDepth(root->left) // root->left 是节点 2

4. 对节点 2 再次递归:

• root 为节点 2,非空,继续。

• 递归计算左子树深度:

l_depth = maxDepth(root->left) // root->left 是节点 4

• root 为节点 4,非空,继续。

• 递归计算左、右子树深度:

maxDepth(root->left) // nullptr,返回 0

maxDepth(root->right) // nullptr,返回 0

• 返回值为:

max(0, 0) + 1 = 1

• 回到节点 2,计算右子树深度:

r_depth = maxDepth(root->right) // root->right 是节点 5

• 类似节点 4,返回深度为 1。

• 返回节点 2 的深度:

max(1, 1) + 1 = 2

5. 回到节点 1,计算右子树深度:

r_depth = maxDepth(root->right) // root->right 是节点 3

• 节点 3 无子节点,直接返回:

max(0, 0) + 1 = 1

6. 最终计算根节点的深度:

max(2, 1) + 1 = 3

执行流程总结

• 从根节点递归到叶子节点,再逐层返回深度。

• 每次返回的是左右子树最大深度 +1。

最终结果

二叉树的最大深度为 3

http://www.lryc.cn/news/523921.html

相关文章:

  • 速通Docker === 网络
  • 【MySQL — 数据库基础】深入解析MySQL常用数据类型
  • Linux高级--3.3.1 C++ spdlog 开源异步日志方案
  • 电梯系统的UML文档05
  • 如何使 LLaMA-Factory 支持 google/gemma-2-2b-jpn-it 的微调
  • MySQL中日期和时间戳的转换:字符到DATE和TIMESTAMP的相互转换
  • HarmonyOS NEXT开发进阶(十):UIAbility 组件交互
  • 深入探索Math.NET:开启高效数值计算之旅
  • AI编程工具横向评测--Cloudstudio塑造完全态的jupyter notebook助力数据分析应用开发
  • 【2024 CSDN博客之星】技术洞察类:从DeepSeek-V3的成功,看MoE混合专家网络对深度学习算法领域的影响(MoE代码级实战)
  • Linux——入门基本指令汇总
  • 54,【4】BUUCTF WEB GYCTF2020Ezsqli
  • 【Leetcode 热题 100】45. 跳跃游戏 II
  • C/C++ 时间复杂度(On)
  • 【STM32-学习笔记-10-】BKP备份寄存器+时间戳
  • React 中hooks之 React.memo 和 useMemo用法总结
  • 日志收集Day001
  • 机器人“大脑+小脑”范式:算力魔方赋能智能自主导航
  • python程序跑起来后,然后引用的数据文件发生了更新,python读取的数据会发生变化吗
  • VSCode最新离线插件拓展下载方式
  • 算法题目总结-栈和队列
  • IO进程----进程
  • 【机器学习实战高阶】基于深度学习的图像分割
  • 「免填邀请码」赋能各类APP,提升转化率与用户体验
  • 基于海思soc的智能产品开发(视频的后续开发)
  • 创建 pdf 合同模板
  • 2024 年度学习总结
  • CSS笔记基础篇02——浮动、标准流、定位、CSS精灵、字体图标
  • C++ 面向对象(继承)
  • Top期刊算法!RIME-CNN-BiLSTM-Attention系列四模型多变量时序预测