CC1-二叉树的最小深度

目录

一、题目描述

二、解题思路

(一)递归的核心思想

(二)算法步骤

三、代码实现

(一)完整代码

(二)代码解释

四、测试结果

五、总结


一、题目描述

求给定二叉树的最小深度。最小深度是指树的根结点到最近叶子结点的最短路径上结点的数量。

示例:输入:[1,2,3,4,5]返回值:2

二、解题思路

(一)递归的核心思想

通过递归的方式,从根节点开始,分别计算左右子树的最小深度,然后取较小值加 1(加上当前根节点),得到整个二叉树的最小深度。需要注意的是,当根节点的左子树或右子树为空时,不能简单地取 0,因为叶子节点必须同时没有左右子节点,所以这种情况下要取非空的子树的深度加 1。

(二)算法步骤

  1. 处理空树情况 :如果根节点 rootnull,直接返回 0,因为空树没有节点,深度为 0。
  2. 处理左子树为空的情况 :如果根节点的左子树 root.leftnull,那么最小深度由右子树的最小深度决定,递归计算右子树的最小深度并加 1(加上当前根节点)。
  3. 处理右子树为空的情况 :如果根节点的右子树 root.rightnull,那么最小深度由左子树的最小深度决定,递归计算左子树的最小深度并加 1(加上当前根节点)。
  4. 处理左右子树都不为空的情况 :此时,最小深度是左子树最小深度和右子树最小深度中的较小值,再加上当前根节点,即 Math.min(run(root.left), run(root.right)) + 1

三、代码实现

(一)完整代码

复制代码
import java.util.*;

// 定义二叉树节点类
class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;
}

public class Solution {
    /**
     * @param root TreeNode类 
     * @return int整型
     */
    public int run(TreeNode root) {
        if (root == null) {
            return 0;
        }
        if (null == root.left) {
            return run(root.right) + 1;
        }
        if (null == root.right) {
            return run(root.left) + 1;
        }
        return Math.min(run(root.left), run(root.right)) + 1;
    }

    // 测试代码
    public static void main(String[] args) {
        // 构建示例中的二叉树 [1,2,3,4,5]
        TreeNode root = new TreeNode();
        root.val = 1;

        TreeNode node2 = new TreeNode();
        node2.val = 2;
        root.left = node2;

        TreeNode node3 = new TreeNode();
        node3.val = 3;
        root.right = node3;

        TreeNode node4 = new TreeNode();
        node4.val = 4;
        node2.left = node4;

        TreeNode node5 = new TreeNode();
        node5.val = 5;
        node2.right = node5;

        Solution solution = new Solution();
        int minDepth = solution.run(root);
        System.out.println("二叉树的最小深度为:" + minDepth);
    }
}

(二)代码解释

  • TreeNode 类 :定义了二叉树的节点结构,包含值 val 以及左右子节点 leftright
  • run 方法:核心的递归方法,按照上述解题思路计算二叉树的最小深度。
  • main 方法 :用于测试,构建了示例中的二叉树,并调用 run 方法计算最小深度,最后输出结果。

四、测试结果

运行测试代码,输入构建的二叉树 [1,2,3,4,5],输出结果为:

复制代码
二叉树的最小深度为:2

与题目示例的预期结果一致,说明代码正确实现了二叉树最小深度的计算。

五、总结

通过递归的方法,我们高效地解决了二叉树最小深度的计算问题。在处理过程中,需要特别注意叶子节点的定义(同时没有左右子节点),避免在子树为空时错误地计算深度。这种递归的思路在树的相关问题中非常常见,掌握它有助于解决更多复杂的树结构问题。

相关推荐
小旭95275 分钟前
Spring Security 实现权限控制(认证 + 授权全流程)
java·后端·spring
金銀銅鐵11 分钟前
[Java] 如何通过 cglib 的 FastClass 调用一个类中的“任意”方法?
java·后端
2301_8227032017 分钟前
鸿蒙flutter三方库实战——教育与学习平台:Flutter Markdown
学习·算法·flutter·华为·harmonyos·鸿蒙
Jia ming28 分钟前
C语言实现日期天数计算
c语言·开发语言·算法
阿维的博客日记29 分钟前
为什么会增加TreeMap和TreeSet这两类,有什么核心优势吗?可以解决什么核心痛点?
java·treeset·treemap
dllxhcjla37 分钟前
黑马头条1
java
宠友信息41 分钟前
一套基于uniapp+springboot完整社区系统是如何实现的?友猫社区源码级功能解析
java·spring boot·后端·微服务·微信·uni-app
humors2211 小时前
各厂商工具包网址
java·数据库·python·华为·sdk·苹果·工具包
无限进步_1 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
苏纪云1 小时前
蓝桥杯考前突击
c++·算法·蓝桥杯