零基础代码随想录【Day16】|| 104.二叉树的最大深度 ,111.二叉树的最小深度,222.完全二叉树的节点个数

目录

DAY16

104.二叉树的最大深度 

解题思路&代码

111.二叉树的最小深度

解题思路&代码

222.完全二叉树的节点个数

解题思路&代码


DAY16

104.二叉树的最大深度 

力扣题目链接(opens new window)

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

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

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

示例: 给定二叉树 [3,9,20,null,null,15,7],

返回它的最大深度 3 。

什么是深度,什么是高度,如何求深度,如何求高度,这里有关系到二叉树的遍历方式。

大家 要先看视频讲解,就知道以上我说的内容了,很多录友刷过这道题,但理解的还不够。

题目链接/文章讲解/视频讲解: 代码随想录

解题思路&代码

思路:

求解二叉树的深度,正常来讲应该采用前序遍历(中左右),一步步向下得到各层的深度,但此处二叉树的深度和高度在数值上是一致的,所以采用后序遍历(左右中)得到各层的高度

class Solution {
    public int maxDepth(TreeNode root) {
        if (root == null) return 0;
        int leftDepth = maxDepth(root.left);//后序遍历分别是左,右,中的处理逻辑
        int rightDepth = maxDepth(root.right);//右子树最大高度
        return Math.max(leftDepth, rightDepth) +1;/**这个+1,考虑极端情况,
即从null的上一层叶子节点开始模拟,此时leftDepth为0、rightDepth为0,
但最底层的叶子节点高度为1,而且每提高一层,高度+1 */

    }
}

111.二叉树的最小深度

力扣题目链接(opens new window)

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

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

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

示例:

给定二叉树 [3,9,20,null,null,15,7],

返回它的最小深度 2.

先看视频讲解,和最大深度 看似差不多,其实 差距还挺大,有坑。

题目链接/文章讲解/视频讲解:代码随想录

解题思路&代码

思路:

主要是最小深度必须找到左右节点都为null的叶子节点,而不是直接取最小就行(与最大深度的差异就在这里)

class Solution {
    public int minDepth(TreeNode root) {
        if (root == null) {  //递归三要素,确定递归函数的参数和返回值,确定终止条件,确定单层递归的逻辑
            return 0;
        }
        int leftDepth = minDepth(root.left);  //确定好左、右、中的处理逻辑,终止条件,会不断循环,所以不用怕极端情况
        int rightDepth = minDepth(root.right);
        if (root.left == null ) {  /**最小深度是从根节点到最近叶子节点的最短路径上的节点数量
(叶子节点是指没有子节点的节点),所以对左节点为null,右节点不为null的情况会持续遍历 */
            return rightDepth + 1;
        }
        if (root.right == null ) {
            return leftDepth + 1;
        }
        // 左右节点都不为null
        return Math.min(leftDepth, rightDepth) +1;
        

    }
}

222.完全二叉树的节点个数

力扣题目链接(opens new window)

给出一个完全二叉树,求出该树的节点个数。

示例 1:

  • 输入:root = [1,2,3,4,5,6]
  • 输出:6

需要了解,普通二叉树 怎么求,完全二叉树又怎么求

题目链接/文章讲解/视频讲解:代码随想录

解题思路&代码

思路:

普通二叉树

首先按照普通二叉树的逻辑来求。

这道题目的递归法和求二叉树的深度写法类似, 而迭代法,二叉树:层序遍历登场! (opens new window)遍历模板稍稍修改一下,记录遍历的节点数量就可以了。

递归遍历的顺序依然是后序(左右中)。

完全二叉树只有两种情况,情况一:就是满二叉树,情况二:最后一层叶子节点没有满。

对于情况一,可以直接用 2^树深度 - 1 来计算,注意这里根节点深度为1。

对于情况二,分别递归左孩子,和右孩子,递归到某一深度一定会有左孩子或者右孩子为满二叉树,然后依然可以按照情况1来计算。

class Solution {
    /**
     * 针对完全二叉树的解法,这一步的终止条件比较复杂,不仅是节点为null,并且还得判断子二叉树是不是完全二叉树,是的话就返回2^depth - 1
     *
     * 满二叉树的结点数为:2^depth - 1
     */
    public int countNodes(TreeNode root) {
        if (root == null) return 0;
        TreeNode left = root.left;
        TreeNode right = root.right;
        int leftDepth = 0, rightDepth = 0; // 这里初始为0是有目的的,为了下面求指数方便
        while (left != null) {  // 求左子树深度
            left = left.left;
            leftDepth++;
        }
        while (right != null) { // 求右子树深度
            right = right.right;
            rightDepth++;
        }
        if (leftDepth == rightDepth) {
            return (2 << leftDepth) - 1; // 注意(2<<1) 相当于2^2,所以leftDepth初始为0
        }
        return countNodes(root.left) + countNodes(root.right) + 1;//不满足满二叉树就往下继续递归,返回左节点个数+右节点个数+当前节点
    }
}

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值