力扣 简单 110.平衡二叉树

文章目录

题目介绍


解法

平衡二叉树:任意节点的左子树和右子树的高度之差的绝对值不超过 1

java 复制代码
//利用递归方法自顶向下判断以每个节点为根节点的左右子树的最大深度是否大于1
class Solution {
    public boolean isBalanced(TreeNode root) {
        if(root == null){
            return true;
        }else {
            return Math.abs(height(root.left) - height(root.right)) <= 1 && isBalanced(root.left) && isBalanced(root.right);
        }
    }

    //以节点为根节点的树的最大深度
    public int height(TreeNode root) {
        if (root == null) {
            return 0;
        } else {
            return Math.max(height(root.left), height(root.right)) + 1;
        }
    }
}
相关推荐
没有bug.的程序员2 小时前
Gradle 构建优化深度探秘:从 Java 核心到底层 Android 物理性能压榨实战指南
android·java·开发语言·分布式·缓存·gradle
-Rane2 小时前
【C++】vector
开发语言·c++·算法
tianyagukechat2 小时前
rockylinux9.5 配置IP
java·网络·tcp/ip
代码栈上的思考2 小时前
滑动窗口算法实战
算法
程序员Sonder2 小时前
黑马java----正则表达式(一文弄懂)
java·正则表达式·新人首发
doris82042 小时前
Python 正则表达式 re.findall()
java·python·正则表达式
Eloudy2 小时前
直接法 读书笔记 06 第6章 LU分解
人工智能·算法·ai·hpc
Anastasiozzzz3 小时前
阿亮随手记:动态条件生成Bean
java·前端·数据库
仰泳的熊猫3 小时前
题目1531:蓝桥杯算法提高VIP-数的划分
数据结构·c++·算法·蓝桥杯
刘琦沛在进步3 小时前
如何计算时间复杂度与空间复杂度
数据结构·c++·算法