平衡二叉树:优化

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;
    }
}

上一篇:每周学一个小*之 可以缩放的ScalableView,移动app开发公司


下一篇:shell脚本自动过滤尝试多次连接ip并添加到系统黑名单