news 2026/6/25 6:08:11

【每天学习一点算法2025/12/16】二叉树的最大深度

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【每天学习一点算法2025/12/16】二叉树的最大深度

每天学习一点算法 2025/12/16

题目:二叉树的最大深度

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

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

要取得二叉树的最大深度,就需要遍历树,二叉树的遍历方法我的另一篇前端算法基础的文章中有介绍,主要就是深度优先和广度优先两种算法。

  1. 深度优先 — 使用递归的方式遍历二叉树

    计算最大深度,关键在于我们要如何找到深度最大的路径,我们知道深度优先分为前序中序后序,区别就在于处理当前遍历值和左右树叉递归调用的顺序,下面是前序遍历的算法,我们来分析一下

    constpreOrderDFS=(root)=>{if(!root)returnresult.push(root.val)preOrderDFS(root.left)preOrderDFS(root.right)returnresult}
    • 我们主要分析递归遍历的过程,当!roottrue时,代表当前路径走到了叶子节点。先序遍历是左节点回归后再进入右节点。
    • 如果我们从叶子节点开始计数,每回归一层+1,然后将数字返回到上一层,这样是不是就可以计算出路径的深度了。
    • 那我们要如何保证计数的是最大深度的路径上的节点呢?只需要每一层取左右节点回归计数值较大的+1返回上一层即可。有点抽象啊,我们简单的举个例子:
      1. 当我们遍历到某一条路径的叶子节点时,返回0到上一层。
      2. 到这个叶子节点这一层时,没有子节点,左右回归计数都是0,返回0+1到上一层。
      3. 到这个叶子节点的父节点这层时,这一侧(可能是left也可能是right)的计数是1,另一侧的计数则要看其子节点的层数情况,哪一侧子层级更深计数就更大,然后就在这基础上+1返回到上一层。
      4. 依次类推每一层都选择计数更大的一侧+1回归,直到回到根节点。

    代码如下:

    functionmaxDepth(root:TreeNode|null):number{if(!root){return0}returnMath.max(maxDepth(root.left),maxDepth(root.right))+1};
  2. 广度优先 — 从根节点开始一层一层的遍历,主要利用队列存储下一列节点的方式,具体实现可以参考我的文章前端算法基础,每次遍历其实就是往下一层拓展,那么拓展的次数就是二叉树的最大深度。

    functionmaxDepth(root:TreeNode|null):number{if(!root)return0;constqueue=[root]// 初始根入遍历队列letcount=0// 用于拓展计数// 循环至遍历队列为空while(queue.length){constlevelSize=queue.length;for(leti=0;i<levelSize;i++){constnode=queue.shift()// 第一项出遍历队列// 按左右顺序 将下一层树节点入遍历队列node.left&&queue.push(node.left)node.right&&queue.push(node.right)}// 每层遍历后计数count++}returncount};

题目来源:力扣(LeetCode)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/24 3:15:14

数据结构05——平衡二叉树

数据结构——平衡二叉树 平衡二叉树定义AVL树AVL树的调整RR 右单旋LL 左单旋LR 旋转RL 旋转总结 平衡二叉树定义 “平衡因子&#xff08;Balanced Factor&#xff0c;简称BF&#xff09;”&#xff1a; B F ( T ) h L − h R BF(T)h_L-h_R BF(T)hL​−hR​&#xff0c;其中 h…

作者头像 李华
网站建设 2026/6/24 22:17:07

深入 Flutter 开发:构建一个带网络请求的天气应用(含完整代码)

标题&#xff1a;深入 Flutter 开发&#xff1a;构建一个带网络请求的天气应用&#xff08;含完整代码&#xff09; 引言 在移动开发领域&#xff0c;Flutter 凭借其高性能、跨平台能力和出色的 UI 表现力&#xff0c;已成为 Google 主推的现代应用开发框架。它使用 Dart 语言…

作者头像 李华
网站建设 2026/6/23 22:20:23

微算法科技(NASDAQ MLGO)链下与机器学习融合:革新区块链可扩展性

区块链技术自诞生以来&#xff0c;凭借去中心化、不可篡改的特性&#xff0c;在金融、供应链、版权保护等领域展现出颠覆性潜力。然而&#xff0c;随着用户规模与交易量的指数级增长&#xff0c;传统区块链架构逐渐暴露出可扩展性不足的瓶颈。公链网络每秒处理几十笔交易的能力…

作者头像 李华
网站建设 2026/6/18 13:25:47

考虑风光出力的虚拟电厂和运营商的主从博弈,分别考虑电动汽车充放电,火电出力,储能设备充放电充放...

考虑风光出力的虚拟电厂和运营商的主从博弈&#xff0c;分别考虑电动汽车充放电&#xff0c;火电出力&#xff0c;储能设备充放电充放电价格等因素外层用改进粒子群算法&#xff0c;目标函数线性加权。最近在折腾虚拟电厂和运营商的主从博弈模型&#xff0c;发现把风光出力、电…

作者头像 李华
网站建设 2026/6/23 22:38:17

不囤货、不开店,如何用一部手机连接1000家品牌

凌晨四点,陈明被一通电话吵醒。电话那头是仓库老王急促的声音:“陈总,那批饼干还有三天过期,今天再处理不掉,就只能当垃圾扔了!” 这已经是这个月第三次了。陈明烦躁地挂掉电话,看着仓库里堆积如山的临期货,心里像压了块石头。他是华南地区某知名饼干品牌的代理商,手里…

作者头像 李华
网站建设 2026/6/24 15:25:07

vue基于Springboot框架二手车托运物流管理系统

目录已开发项目效果实现截图开发技术系统开发工具&#xff1a;核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&…

作者头像 李华