【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;
    }
}
相关推荐
良木生香2 分钟前
【诗句结构-初阶】详解栈和队列(2)---队列
c语言·数据结构·算法·蓝桥杯
yaoh.wang4 分钟前
力扣(LeetCode) 69: x 的平方根 - 解法思路
python·算法·leetcode·面试·职场和发展·牛顿法·二分法
!停5 分钟前
数据在内存中的存储(2)
开发语言·c++·算法
认真学GIS6 分钟前
逐3小时降水量!全国2421个气象站点1951-2024年逐3小时尺度长时间序列降水量(EXCEL格式)数据
人工智能·算法·机器学习
智航GIS10 分钟前
ArcGIS大师之路500技---039趋势面法
算法·arcgis
智航GIS11 分钟前
ArcGIS大师之路500技---038反距离权重法
算法·arcgis
YGGP15 分钟前
【Golang】LeetCode 31. 下一个排列
算法·leetcode
小猪咪piggy16 分钟前
【算法】leetcode100 堆、栈
算法
元亓亓亓19 分钟前
LeetCode热题100--70. 爬楼梯--简单
算法·leetcode·职场和发展
牛客企业服务19 分钟前
牛客AI面试蓝领案例:破解制造业招聘效率困局
人工智能·面试·职场和发展