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

[面试精选] 0104. 二叉树的最大深度

文章目录

      • 1. 题目链接
      • 2. 题目描述
      • 3. 题目示例
      • 4. 解题思路
      • 5. 题解代码
      • 6. 复杂度分析

1. 题目链接


104. 二叉树的最大深度 - 力扣(LeetCode)


2. 题目描述


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

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


3. 题目示例


示例 1 :

输入:root = [3,9,20,null,null,15,7]
输出:3

示例 2 :

输入:root = [1,null,2]
输出:2

4. 解题思路


  1. 递归DFS遍历
    • 采用深度优先搜索(DFS)策略
    • 从根节点开始向下递归遍历每个节点
  2. 深度计算
    • 每进入一个非空节点,当前深度+1
    • 使用全局变量ans记录遍历过程中遇到的最大深度
  3. 递归终止
    • 遇到空节点时返回(递归基线条件)
    • 非空节点继续向左右子树递归
  4. 关键点
    • 前序遍历顺序(先处理当前节点,再处理子树)
    • 深度参数在递归调用中传递
    • 全局变量记录最大值

5. 题解代码


class Solution {private int ans;  // 存储最大深度结果public int maxDepth(TreeNode root) {dfs(root, 0);  // 从根节点开始深度优先搜索,初始深度为0return ans;    // 返回最大深度}// 递归深度优先搜索方法private void dfs(TreeNode node, int depth) {if (node == null) return;  // 基线条件:空节点返回depth++;  // 当前节点深度+1ans = Math.max(ans, depth);  // 更新最大深度// 递归处理左右子树dfs(node.left, depth);dfs(node.right, depth);}
}

6. 复杂度分析


  1. 时间复杂度:O(n)
    • 每个节点恰好被访问一次
    • n为树中节点总数
  2. 空间复杂度:O(h)
    • 递归调用栈的深度等于树的高度h
    • 最坏情况下(链表状树)为O(n)
    • 平衡二叉树情况下为O(log n)
http://www.lryc.cn/news/2404580.html

相关文章:

  • 图上合成:用于大型语言模型持续预训练的知识合成数据生成
  • MYSQL(二) ---MySQL 8.4 新特性与变量变更
  • 数学复习笔记 27
  • 现代简约壁炉:藏在极简线条里的温暖魔法
  • 限流算法java实现
  • 机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
  • Linux 下关于 ioremap 系列接口
  • 常用函数库之 - std::function
  • php执行系统命令的四个常用函数
  • 力扣-17.电话号码的字母组合
  • 基于SpringBoot解决RabbitMQ消息丢失问题
  • 免费插件集-illustrator插件-Ai插件-随机填色
  • 使用 Unstructured 开源库快速入门指南
  • 白银6月想法
  • OpenCV 滑动条调整图像对比度和亮度
  • 船舶事故海上搜救VR情景演练全场景 “复刻”,沉浸式救援体验​
  • 使用Caddy在Ubuntu 22.04上配置HTTPS反向代理
  • 无人机目标检测与语义分割数据集(猫脸码客)
  • Web设计之登录网页源码分享,PHP数据库连接,可一键运行!
  • Cursor + Claude 4:微信小程序流量主变现开发实战案例
  • ㊗️高考加油
  • Redis Key过期策略
  • 【C/C++】实现固定地址函数调用
  • 多模态大语言模型arxiv论文略读(109)
  • 性能优化笔记
  • bat批量去掉本文件夹中的文件扩展名
  • 基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
  • Scrapy爬虫教程(新手)
  • 数据可视化大屏案例落地实战指南:捷码平台7天交付方法论
  • 第五篇:Go 并发模型全解析——Channel、Goroutine