判断二叉树是否是平衡二叉树(LeetCode--110平衡二叉树)

题目

判断一棵二叉树是否是平衡二叉树。(平衡二叉树每个节点的左右两个子树的高度差的绝对值不超过1。)

解题方法

  1. 从根节点开始,首先判断其左右子树高度差的绝对值是否小于等于1,否则直接判定不是平衡二叉树;
  2. 当step1中左右子树高度差的绝对值小于等于1时,分别判断左右孩子节点是否满足平衡条件;
  3. 同样左右孩子判断他们的左右子树高度差,然后再继续判断他们的左右孩子节点,依次递归

注意:这里不同于之前的递归实现,之前的递归大多只需要获取依赖的上一步递归结果即可,这里除了上一步的左右子树是否平衡的递归结果以外,还需要判断自身的左右子树高度差

代码

public boolean isBalanced(TreeNode root) {
    if(root == null){//空树为平衡树
        return true;
    }
    int lh = treeHeight(root.left);//左子树高
    int rh = treeHeight(root.right);//右子树高
    if(Math.abs(lh - rh) > 1){//如果左右子树高度差绝对值超过1,则不平衡
        return false;
    }
    //递归判断节点的左右孩子节点是否满足平衡条件
    return isBalanced(root.left) && isBalanced(root.right);
}

//二叉树树高
private int treeHeight(TreeNode root){
    if(null == root){//空节点高为0
        return 0;
    }
    int leftHeight = treeHeight(root.left);//左子树树高
    int rightHeight = treeHeight(root.right);//右子树树高
    //当前节点高为左右子树高度最大值加1
    return leftHeight >= rightHeight ? (leftHeight + 1) : (rightHeight + 1);
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 通过之前对二叉搜索树介绍可知,将集合构造为二叉搜索树结构,该结构下对树中节点的查询、删除和插入三种操作,时间复杂度...
    zhipingChen阅读 29,297评论 0 19
  • 一、二叉查找树 1、定义:二叉查找树,也称二叉搜索树,或二叉排序树。其定义也比较简单,要么是一颗空树,要么就是具有...
    小小宁儿阅读 3,329评论 0 9
  • 介绍 二叉树的结构 二叉树常考的原因有如下几点1、它可以结合链表、栈、队列和字符串等数据结构出题2、需要熟练掌握图...
    雨住多一横阅读 456评论 0 1
  • 1. 树的概念 一个树由节点组成,这些节点包含根节点,父节点,子节点,兄弟节点;没有任何一个节点的树称为空树;如果...
    HChase阅读 6,397评论 0 34
  • 最近比较忙,没闲得下时间写简书。小编在之前的分享中有讲过二叉搜索树,如下的两颗树都满足二叉搜索树的条件。 图片...
    ITsCLG阅读 938评论 0 1