美文网首页
55.二叉树的深度(简单)

55.二叉树的深度(简单)

作者: 今天柚稚了么 | 来源:发表于2020-02-22 12:23 被阅读0次

考点:本题考查树,知识迁移能力

题目一描述

输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。
给定二叉树 [3,9,20,null,null,15,7],返回它的最大深度 3 。

思路:递归

如果一棵树只有一个节点,那么它的深度为1。如果根节点只有左子树而没有右子树,那么树的深度应该是其左子树的深度加1;如果根节点只有右子树而没有左子树,那么树的深度应该是其右子树的深度加1;如果既有左子树又有右子树,那么树的深度就是其左右子树深度的较大值再加1。

/**
public class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;

    public TreeNode(int val) {
        this.val = val;

    }
}
*/
public class Solution {
    public int TreeDepth(TreeNode root) {
        if(root == null)
            return 0;
        int leftDepth = TreeDepth(root.left);
        int rightDepth = TreeDepth(root.right);
        int result = 1 + ((leftDepth > rightDepth)?leftDepth:rightDepth);
        return result;
    }
}

题目二描述

输入一棵二叉树的根节点,判断该树是不是平衡二叉树。如果某二叉树中任意节点的左右子树的深度相差不超过1,那么它就是一棵平衡二叉树。
给定二叉树 [3,9,20,null,null,15,7],返回true。

思路一:递归

调用函数TreeDepth得到它的左右子树的深度,如果每个节点的左右子树的深度相差都不超过1,那么按照定义它就是一棵平衡二叉树。

public class Solution {
    public boolean IsBalanced_Solution(TreeNode root) {
        if(root == null)
            return true;
        int leftLength = TreeDepth(root.left);
        int rightLength = TreeDepth(root.right);
        int dif = leftLength-rightLength;
        if(dif<-1||dif>1)
            return false;
        return (IsBalanced_Solution(root.left))&&(IsBalanced_Solution(root.right));
        
    }
     public int TreeDepth(TreeNode root) {
        if(root == null)
            return 0;
        int leftDepth = TreeDepth(root.left);
        int rightDepth = TreeDepth(root.right);
        int result = 1 + ((leftDepth > rightDepth)?leftDepth:rightDepth);
        return result;
    }
}

但是此方法会导致一个节点会被重复遍历多次

思路二:后序遍历

遍历左右根,判断每个节点是否是平衡节点。当遍历到一个根节点时,先遍历该根节点的左右子树,计算左右子树的深度并通过传址的方式进行向上传递;如果该根节点是平衡节点,则向上遍历该节点的父节点,父节点的深度在之前传递的深度基础上加1即可,因此避免了节点的重复遍历,提高了效率。

public class Solution {
public boolean IsBalanced_Solution(TreeNode root) {
        int[] depth = {0};
        return isBalancedTree(root, depth);
    }

    //深度,数组传址参数,需要在函数调用后改变depth,参与运算
    public boolean isBalancedTree(TreeNode root, int[] depth) {
        if(root == null) {
            depth[0] = 0;
            return true;
        }

        // 数组传址参数,用于传递函数调用后的数据,参与运算
        int[] leftDepth = {0};
        int[] rightDepth = {0};
        if(isBalancedTree(root.left, leftDepth) && isBalancedTree(root.right, rightDepth)) {
            int diffDepth = leftDepth[0] - rightDepth[0];
            if(diffDepth >= - 1 && diffDepth <= 1) {
                int tmpDepth = (leftDepth[0] > rightDepth[0]) ? leftDepth[0] : rightDepth[0];
                depth[0] = 1 + tmpDepth;
                return true;
            }
        }
        return false;
    }
}

相关文章

  • 55.二叉树的深度(简单)

    考点:本题考查树,知识迁移能力 题目一描述 输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶...

  • LeetCode 深度优先遍历

    概述 前言 104 二叉树的最大深度【简单】 111 二叉树的最小深度 【简单】 124 二叉树中的最大路径和 【...

  • LeetCode-python 104.二叉树的最大深度

    题目链接难度:简单 类型: 二叉树,递归 给定一个二叉树,找出其最大深度。 二叉树的深度为根节...

  • LeetCode 每日一题 [69] 二叉树的深度

    LeetCode 二叉树的深度 [简单] 输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含...

  • Minimum Depth of Binary Tree二叉树最

    Easy 给定二叉树,返回最浅深度。 简单的递归问题,与二叉树最大深度类似。注意:如果一棵树只有左或右节点,这个树...

  • 二叉树的最大深度

    题目 难度级别:简单 给定一个二叉树,找出其最大深度。 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。 ...

  • 二叉树面试题基本问题

    二叉树的最大深度与最小深度 二叉树的最大深度 最大深度是指二叉树根节点到该树叶子节点的最大路径长度。而最小深度自然...

  • LeetCode 力扣 104. 二叉树的最大深度

    题目描述(简单难度) 输出二叉树的深度。 解法一 DFS 依旧是考的二叉树的遍历。最简单的思路就是用递归进行 D...

  • 111. Minimum Depth of Binary Tre

    题目 给定一个二叉树,求二叉树最小深度 解析 一个二叉树的最小深度,就是求左子树最小深度或者右子树最小深度,然后加...

  • LeetCode-python 257.二叉树的所有路径

    题目链接难度:简单 类型: 二叉树、深度优先搜索 给定一个二叉树,返回所有从根节点到叶子节点的...

网友评论

      本文标题:55.二叉树的深度(简单)

      本文链接:https://www.haomeiwen.com/subject/hulsfhtx.html