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

13-二叉树最小深度-深度优先(DFS)

一、定义

什么是二叉树的最小深度?

二叉树的最小深度是指从根节点到最近的叶子节点的最短路径上的节点数。叶子节点是指没有子节点的节点。

举个例子:

     1/ \2   3/ 4

这棵树的最小深度是 2,因为从根节点 1 到叶子节点 3 的路径最短,只需要经过 1 和 3 两个节点。


深度优先搜索(DFS)的思路

深度优先搜索是一种遍历树的方法,它的特点是一条路走到底,直到遇到叶子节点或者无法继续前进时,再回溯到上一个节点,尝试其他路径。

用 DFS 求最小深度的步骤如下:

  1. 从根节点开始,递归地遍历它的左子树和右子树。

  2. 如果当前节点是叶子节点(即没有左子树和右子树),返回深度 1。

  3. 如果当前节点只有左子树或右子树,继续递归遍历存在的子树。

  4. 如果当前节点有左右子树,分别递归计算左右子树的最小深度,然后取较小的那个,再加上当前节点的深度 1。

  5. 最终返回最小深度


举个例子

假设我们有一棵树:

     1/ \2   3/ \4   5

用 DFS 计算最小深度的过程如下:

  1. 从根节点 1 开始,递归遍历左子树 2

    • 节点 2 是叶子节点,返回深度 1。

  2. 递归遍历右子树 3

    • 节点 3 有左右子树,递归遍历左子树 4

      • 节点 4 是叶子节点,返回深度 1。

    • 递归遍历右子树 5

      • 节点 5 是叶子节点,返回深度 1。

    • 节点 3 的最小深度是 min(1, 1) + 1 = 2

  3. 根节点 1 的最小深度是 min(1, 2) + 1 = 2

所以这棵树的最小深度是 2。

二,举例

计算该二叉树的最小深度:

            1/ \2   3/ \   \4   5   6\7
import javax.swing.tree.TreeNode;public class demo01 {public static void main(String[] args) {TreeNode node7 =new TreeNode(7,null,null);TreeNode node6 =new TreeNode(6,node7,null);TreeNode node5 =new TreeNode(5,null,null);TreeNode node4 =new TreeNode(4,null,null);TreeNode node3 =new TreeNode(3,node6,null);TreeNode node2 =new TreeNode(2,node4,node5);TreeNode node1 =new TreeNode(1,node2,node3);System.out.println(minDepth(node1));}public static int minDepth(TreeNode root) {if (root == null) {return 0;}if (root.left == null && root.right == null) {return 1;}int min=Integer.MAX_VALUE;if(root.left != null) {                      //左边节点不为空min=Math.min(minDepth(root.left),min);    //算出左边节点}if(root.right != null) {                        //左边节点不为空min=Math.min(minDepth(root.right),min);   //算出左边节点}return min+1;}static class TreeNode {int val;TreeNode left;TreeNode right;TreeNode(int val,TreeNode left,TreeNode right) {this.val = val;this.left = left;this.right = right;}}
}
http://www.lryc.cn/news/539097.html

相关文章:

  • 51单片机入门_10_数码管动态显示(数字的使用;简单动态显示;指定值的数码管动态显示)
  • 代码补全『三重奏』:EverEdit如何用上下文识别+语法感知+智能片段重构你的编码效率!
  • 电脑系统损坏,备份文件
  • Token Statistics Transformer:线性注意力革命,重新定义Transformer效率天花板
  • Django 5实用指南(二)项目结构与管理
  • JAVA监听器(学习自用)
  • Ubuntu下mysql主从复制搭建
  • VirtualBox 中使用 桥接网卡 并设置 MAC 地址
  • Ubuntu 20 掉显卡驱动的解决办法
  • EasyPoi系列之框架集成及基础使用
  • Web后端 Tomcat服务器
  • 【RK3588嵌入式图形编程】-SDL2-构建模块化UI
  • 面向机器学习的Java库与平台简介、适用场景、官方网站、社区网址
  • 基于YOLO11深度学习的心脏超声图像间隔壁检测分割与分析系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分割、人工智能
  • ubuntu24基于虚拟机无法从主机拖拽文件夹
  • 常用Webpack Loader汇总介绍
  • 剑指 Offer II 023. 两个链表的第一个重合节点
  • 个人搭建CDN加速服务 特网科技
  • 用deepseek学大模型08-卷积神经网络(CNN)
  • 蓝桥杯单片机基础部分——6、555定时器
  • Python学习心得函数
  • 神经网络实验——MLP
  • 配置Api自动生成
  • dify-AI 私有部署可修改前端页面
  • 使用 @Results 注解来手动指定字段映射
  • 数据治理中 大数据处理一般都遵循哪些原则
  • 从0到1:STM32温控系统开发踩坑指南
  • 修改时无条件,可以自定义id条件(通过查询)
  • 工业制造能耗管理新突破,漫途MTIC-ECM平台助力企业绿色转型!
  • 实现一个简单的协同过滤推荐算法