怒刷力扣( 二叉树的最小深度)

简介: 这个题的坑就是没有左右子树的时候,这个节点才是叶子节点,这时候计算的结果才是根节点到叶子节点的深度。

二叉树的最小深度

WangScaler: 一个用心创作的作者。

声明:才疏学浅,如有错误,恳请指正。

题目

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

说明: 叶子节点是指没有子节点的节点。

初次分析

这个二叉树的深度,我们之前已经做过了。比如平衡二叉树,我们也要计算每个子树的深度。我们只需要返回左右子树的深度最小值即可。

public int minDepth(TreeNode root) {
    if(root==null){return 0;}
    return Math.min(minDepth(root.left)+1,minDepth(root.right)+1);
​
}

继续分析

但是提交代码之后,发现执行失败

image.png

这个二叉树的左子树为空,只有右子树。所以根节点不是叶子节点,算出来的1不是正确答案,那么答案就是根节点到他右子树叶子节点的深度。

所以我们要单独的处理这种情况,那么这种情况就是判断根节点的左右子树一方为空的情况。

  • 左右子树都为空,那么这个节点就是叶子节点,那么到自身的距离就是1。
  • 左子树为空,那么深度就是根节点到右子树叶子节点的距离。
  • 右子树为空,那么深度就是根节点到左子树叶子节点的距离。

答案

public int minDepth(TreeNode root) {
        if(root==null){return 0;}
        if(root.left==null&&root.right==null){
            return 1;
        }
        if(root.left==null||root.right==null){
            return minDepth(root.left==null?root.right:root.left)+1;
        }
        return Math.min(minDepth(root.left)+1,minDepth(root.right)+1);
​
    }

复杂度

  • 时间复杂度: O(n),其中 n 是二叉树中的节点个数。最坏的情况就是满二叉树,所有节点都会遍历。
  • 空间复杂度:O(n),递归调用占用的栈空间,其中n就是二叉树的高度。

总结

以上的方法是基于深度优先的算法。这个题的坑就是没有左右子树的时候,这个节点才是叶子节点,计算的结果才是根节点到叶子节点的深度。

找到这个条件之后,这个题其实就不难了。二叉树的深度如下图所示。

image.png

都来了,点个赞再走呗!

关注WangScaler,祝你升职、加薪、不提桶!

目录
相关文章
|
2月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
44 6
|
2月前
|
存储 算法
二叉树进阶-学会层序遍历助你一次刷完leetcode10道题
文章深入探讨了二叉树的层序遍历方法,并展示了如何通过队列实现层序遍历的算法逻辑,同时指出掌握层序遍历技巧可以帮助解决LeetCode上的多道相关题目。
二叉树进阶-学会层序遍历助你一次刷完leetcode10道题
|
2月前
|
Python
【Leetcode刷题Python】114. 二叉树展开为链表
LeetCode上114号问题"二叉树展开为链表"的Python实现,通过先序遍历二叉树并调整节点的左右指针,将二叉树转换为先序遍历顺序的单链表。
23 3
【Leetcode刷题Python】114. 二叉树展开为链表
|
2月前
|
算法 Java
LeetCode第94题二叉树的中序遍历
文章介绍了LeetCode第94题"二叉树的中序遍历"的解法,使用递归实现了中序遍历的过程,遵循了"左根右"的遍历顺序,并提供了清晰的Java代码实现。
LeetCode第94题二叉树的中序遍历
|
2月前
|
索引 Python
【Leetcode刷题Python】从列表list中创建一颗二叉树
本文介绍了如何使用Python递归函数从列表中创建二叉树,其中每个节点的左右子节点索引分别是当前节点索引的2倍加1和2倍加2。
38 7
|
2月前
|
存储 算法 Python
【Leetcode刷题Python】297. 二叉树的序列化与反序列化
LeetCode第297题"二叉树的序列化与反序列化"的Python语言解决方案,包括序列化二叉树为字符串和反序列化字符串为二叉树的算法实现。
22 5
|
2月前
|
Python
【Leetcode刷题Python】236. 二叉树的最近公共祖先
LeetCode上236号问题"二叉树的最近公共祖先"的Python实现,使用递归方法找到两个指定节点的最近公共祖先。
29 5
|
2月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - II. 从上到下打印二叉树 II
本文提供了一种Python实现方法,用于层次遍历二叉树并按层打印结果,每层节点按从左到右的顺序排列,每层打印到一行。
30 3
|
2月前
|
Python
【Leetcode刷题Python】199. 二叉树的右视图
LeetCode上199号问题"二叉树的右视图"的Python实现,通过深度优先搜索算法按层序从右向左访问节点,以获取每层的最右边节点的值。
21 4
|
2月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - I. 从上到下打印二叉树
本文介绍了使用Python实现从上到下打印二叉树的解决方案,采用层次遍历的方法,利用队列进行节点的访问。
30 2