其他分享
首页 > 其他分享> > 平衡二叉树:优化

平衡二叉树:优化

作者:互联网

110. 平衡二叉树

优化:在计算高度那里去直接判断

难度简单869

给定一个二叉树,判断它是否是高度平衡的二叉树。

本题中,一棵高度平衡二叉树定义为:

一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:true

示例 2:

输入:root = [1,2,2,3,3,null,null,4,4]
输出:false

示例 3:

输入:root = []
输出:true
class Solution {
     public int getHeight(TreeNode root){
        if(root == null) return 0;
        int leftHeight = getHeight(root.left);
        int rightHeight = getHeight(root.right);
        if(leftHeight>=0 && rightHeight>=0 && Math.abs(leftHeight-rightHeight)<=1){
            return Math.max(leftHeight,rightHeight)+1;
        }else{
            return -1;
        }
    }
    public boolean isBalanced(TreeNode root) {
        if(root == null) return true;
        return getHeight(root)>=0;
    }
}

标签:示例,int,优化,getHeight,二叉树,平衡,null,root
来源: https://blog.csdn.net/weixin_59551524/article/details/122581116