【LeetCode-简单题】110. 平衡二叉树

文章目录

题目

方法一:后序递归

递归遍历的同时判断是否是平衡二叉树,如果不是,就置为-1,如果是 就正常做递归求最大深度

参考图解网址
判断平衡二叉树

java 复制代码
class Solution {
    public boolean isBalanced(TreeNode root) {
         return  dfs(root) !=-1;
    }
    public int dfs(TreeNode root){
        if(root == null) return 0;
        
        int left = dfs(root.left);
        if(left==-1) return -1;// 左子树高度差大于1,return -1表示已经不是平衡树了  就无需去递归右子树了
        int right = dfs(root.right);
        if(right==-1) return -1;// 右子树高度差大于1,return -1表示已经不是平衡树了

        if(Math.abs(left-right)>1) return -1;  // 左右子树高度差大于1,return -1表示已经不是平衡树了
        else return Math.max(left,right)+1;
    }
}
相关推荐
阿贵---几秒前
C++中的备忘录模式
开发语言·c++·算法
setmoon21416 分钟前
C++中的观察者模式实战
开发语言·c++·算法
2403_8355684718 分钟前
C++代码规范化工具
开发语言·c++·算法
tankeven33 分钟前
HJ138 在树上游玩
c++·算法
lihihi1 小时前
P1209 [USACO1.3] 修理牛棚 Barn Repair
算法
weixin_387534221 小时前
Ownership - Rust Hardcore Head to Toe
开发语言·后端·算法·rust
xsyaaaan1 小时前
leetcode-hot100-链表
leetcode·链表
庞轩px2 小时前
MinorGC的完整流程与复制算法深度解析
java·jvm·算法·性能优化
Queenie_Charlie2 小时前
Manacher算法
c++·算法·manacher
闻缺陷则喜何志丹2 小时前
【树的直径 离散化】 P7807 魔力滋生|普及+
c++·算法·洛谷·离散化·树的直径