104.二叉树的最大深度——二叉树专题复习

在这里插入图片描述
深度优先搜索(DFS)是一种常用的递归算法,用于解决树形结构的问题。在计算二叉树的最大深度时,DFS方法会从根节点开始,递归地计算左右子树的最大深度,然后在返回时更新当前节点所在路径的最大深度。

如果我们知道了左子树和右子树的最大深度 left 和 right,那么该二叉树的最大深度即为 max(left ,right)+1

递归实现:

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val*         this.left = left;*         this.right = right;*     }* }*/
class Solution {// 定义一个方法,递归地计算二叉树的最大深度public int maxDepth(TreeNode root) {// 如果根节点为空,则返回0,树的高度为0if(root == null) return 0;// 递归地计算左子树的最大深度int left = maxDepth(root.left);// 递归地计算右子树的最大深度int right = maxDepth(root.right);// 返回左子树和右子树中的最大深度,加上当前节点的高度1return Math.max(left,right)+1;}
}

二叉树的最大深度可以使用广度优先搜索(BFS)来求解,而且可以通过修改BFS的方式来实现。这种方法与之前提到的BFS方法的区别在于,它是逐层地遍历二叉树,而不是逐个节点地遍历。

迭代实现

class Solution {// 定义一个队列,用于广度优先搜索(BFS)Queue<TreeNode> que = new LinkedList<>();public int maxDepth(TreeNode root) {// 如果根节点为空,则返回0,树的高度为0if(root == null) return 0;// 将根节点加入队列que.offer(root);// 初始化结果变量为0,用于记录最大深度int res = 0;// 当队列不为空时,执行循环while(!que.isEmpty()){// 获取队列的当前大小,用于下面的循环控制int size = que.size();// 当队列中还有节点时,执行循环while(size > 0){// 从队列中取出一个节点TreeNode node = que.poll();// 如果当前节点的左子节点不为空,将其加入队列if(node.left != null){que.offer(node.left);}// 如果当前节点的右子节点不为空,将其加入队列if(node.right != null){que.offer(node.right);}// 队列大小减1,因为已经取出了一个节点size--;}// 结果变量加1,表示高度增加了res++;}// 返回计算出的最大深度return res;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/866187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PyAutoGUI 使用详解

文章目录 简介PyAutoGUI 的原理安装 PyAutoGUI基本使用示例鼠标控制键盘控制截屏图像识别消息框 高级功能防止误操作多屏幕支持鼠标平滑移动 结论 简介 PyAutoGUI 是一个用于自动化控制鼠标和键盘的 Python 库。它可以帮助开发者编写脚本&#xff0c;以模拟用户在计算机上的操…

每日复盘-20240704

今日关注&#xff1a; 20240704 六日涨幅最大: ------1--------300391--------- 长药控股 五日涨幅最大: ------1--------300391--------- 长药控股 四日涨幅最大: ------1--------300391--------- 长药控股 三日涨幅最大: ------1--------300391--------- 长药控股 二日涨幅最…

[笔记]小米CyberDog机器狗仿真调试记录

从官方github的所有源码库来看&#xff0c;所有的source命令只有两条&#xff0c;执行它以配置环境变量&#xff1a; source /opt/ros/galactic/setup.bash source /home/cyberdog_ws/install/setup.bash 如果运行脚本之后gazebo正常启动及机器狗模型在悬空状态&#xff0c;问…

三位数重新排列c++

题目描述 给你一个三位数 n&#xff08;保证最高位不是 0&#xff09;&#xff0c;你可以重新调整它三个数位的顺序&#xff0c;请输出结果最小的一种。 输入 第一行一个整数 n。 输出 一行一个整数&#xff0c;重新调整顺序后&#xff0c;最小的结果。 注意&#xff0c;…

文心一言 VS 讯飞星火 VS chatgpt (295)-- 算法导论21.4 4题

四、利用练习 21.4-2 &#xff0c;请给出一个简单的证明&#xff0c;证明在一个不相交集合森林上使用按秩合并策略而不使用路径压缩策略的运行时间为 O(m lgn) 。21.4-2 的内容是&#xff1a;“证明&#xff1a;每个结点的秩最多为 ⌊lgn⌋ 。”。如果要写代码&#xff0c;请用…

objdump

objdump是一个用于在Linux系统中查看和解析对象文件&#xff08;如可执行文件、目标文件和共享库&#xff09;的命令行工具。它可以展示文件的多种信息&#xff0c;包括汇编代码、符号表、调试信息等。objdump的常用选项包括&#xff1a; -d 或 --disassemble&#xff1a;反汇编…

vue模板语法v-html

模板语法v-html vue使用一种基于HTML的模板语法&#xff0c;使我们能够声明式的将其组件实例的数据绑定到呈现的DOM上&#xff0c;所有的vue模板都是语法层面的HTML&#xff0c;可以被符合规范的浏览器和HTML解释器解析。 一.文本插值 最基本的数据绑定形式是文本插值&#…

Kafka 为何如此之快?深度解析其背后的秘密

目录 前言 一、生产者 1. 异步发送 2. 多分区并行 3. 消息批量发送 4.支持消息压缩 二、存储端 1. 分区和副本 2. 页缓存 3. 磁盘顺序写入 4. 零拷贝技术 5. 稀疏索引 三、消费端 1. 消费者群组 2. 批量拉取 3. 高效的偏移量管理 4. 并行消费 总结 前言 Kafk…

CS算法(二)—— 斜视SAR点目标仿真

SAR成像专栏目录 我们按照Cumming教授所著的《合成孔径雷达成像——算法与实现》7.6节的点目标参数进行仿真,斜视角设置为8,中心斜距改为1000km。先放最终的仿真结果: 1. 参数配置 在中心点和中心的的上下左右方向设置5个点目标 : function para=config_sar_para_cumming(…

【python数据处理】— “2020-01-01 05:20:15“日期格式数据

文章目录 一、数据说明及目标二、实现方式1.提取date2.提取hour3.提取weekday4.提取month 一、数据说明及目标 数据说明 数据表有一列名为"datetime"表示时间数据&#xff0c;该列的数据格式是"2020-01-01 05:20:15"。 import pandas as pd datapd.read_e…

[数据集][目标检测]刀具匕首持刀检测数据集VOC+YOLO格式8810张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;8810 标注数量(xml文件个数)&#xff1a;8810 标注数量(txt文件个数)&#xff1a;8810 标注…

C++基础语法:引用

前言 "打牢基础,万事不愁" .C的基础语法的学习 引入 引用是C里的概念,和C语言里的"指针常量"是类似的.在C里用得还挺多的,书中明确说明了类对象做参数时,传入类对象的引用.在<<C Prime Plus>> 6th Edition第274页有使用推荐 .用引用来回顾指针…

uniapp+python使用临时签名上传腾讯云oss对象储存方案

概述 uniapp使用临时签名上传腾讯云oss对象储存方案&#xff0c;支持小程序、app、h5&#xff1b; 前端不依赖腾讯云SDK工具类&#xff1b; 后端使用python实现&#xff0c;需要安装qcloud-python-sts&#xff1b; 其中计算文件md5值使用了条件编译&#xff0c;因为每个环境获…

堆结构、堆排序

堆 是完全二叉树&#xff0c;类似这种样式的 而这种有右子节点&#xff0c;没左子节点的就不是完全二叉树 分为大根堆和小根堆 大根堆是二叉树里每一颗子树的父节点都是这颗子树里最大的&#xff0c;即每一棵子树最大值是头节点的值 小根堆相反 把数组中从0开始的一段数人…

Spring Bean生命周期

Bean生命周期&#xff1a; 创建 Bean 的实例&#xff1a;Bean 容器首先会找到配置文件中的 Bean 定义&#xff0c;然后使用 Java 反射 API 来创建 Bean 的实例。 Bean 属性赋值/填充&#xff1a;为 Bean 设置相关属性和依赖&#xff0c;例如Autowired 等注解注入的对象、Value…

强强联合!当RAG遇到长上下文,滑铁卢大学发布LongRAG,效果领先GPT-4 Turbo 50%

过犹不及——《论语先进》 大学考试时&#xff0c;有些老师允许带备cheet sheet&#xff08;忘纸条&#xff09;,上面记着关键公式和定义,帮助我们快速作答提高分数。传统的检索增强生成(RAG)方法也类似,试图找出精准的知识片段来辅助大语言模型(LLM)。 但这种方法其实有问题…

React@16.x(48)路由v5.x(13)源码(5)- 实现 Switch

目录 1&#xff0c;原生 Switch 的渲染内容2&#xff0c;实现 1&#xff0c;原生 Switch 的渲染内容 对如下代码来说&#xff1a; import { BrowserRouter as Router, Route, Switch } from "react-router-dom"; function News() {return <div className"p…

17.上线文管理器,等面向操作

1.new 创建对象实例,在实例对象被创建前调用,与之相对的是__init__, __new__方法必须返回一个类的实例对象,通常情况下会调用父类的__new__方法来创建实例,并返回实例对象. 第一个参数是cls __new__方法允许你控制实例的创建过程,可以实现自定义的逻辑. 单例模式,无论实例化多少…

MySQL体系架构

1.1.MySQL的分支与变种 MySQL变种有好几个&#xff0c;主要有三个久经考验的主流变种&#xff1a;Percona Server&#xff0c;MariaDB和 Drizzle。它们都有活跃的用户社区和一些商业支持&#xff0c;均由独立的服务供应商支持。同时还有几个优秀的开源关系数据库&#xff0c;值…