【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;
    }
}
相关推荐
梨子串桃子_40 分钟前
推荐系统学习笔记 | PyTorch学习笔记
pytorch·笔记·python·学习·算法
夏鹏今天学习了吗1 小时前
【LeetCode热题100(83/100)】最长递增子序列
算法·leetcode·职场和发展
情缘晓梦.1 小时前
C语言指针进阶
java·开发语言·算法
北邮刘老师2 小时前
智能体治理:人工智能时代信息化系统的全新挑战与课题
大数据·人工智能·算法·机器学习·智能体互联网
AlenTech2 小时前
155. 最小栈 - 力扣(LeetCode)
算法·leetcode·职场和发展
mit6.8243 小时前
正反两次扫描|单调性cut
算法
Yzzz-F3 小时前
牛客小白月赛127 E
算法
大锦终3 小时前
递归回溯综合练习
c++·算法·深度优先
Keep__Fighting3 小时前
【神经网络的训练策略选取】
人工智能·深度学习·神经网络·算法
码农水水3 小时前
蚂蚁Java面试被问:混沌工程在分布式系统中的应用
java·linux·开发语言·面试·职场和发展·php