一、题目描述
输入一棵二叉树的根节点,判断该树是不是平衡二叉树。如果某二叉树中任意节点的左右子树的深度相差不超过1,那么它就是一棵平衡二叉树。
二、解题思路
平衡二叉树必须要满足两个条件:
第一:左右子树的高度不能超过1。
第二:根节点下的任意其它子树也必须是平衡二叉树。
对于条件一只需要先求出左右子树的深度然后再进行判断即可,条件二对于整个树判断是否平衡,每个子树也要判断,可以使用递归。
三、代码编写步骤
第一步:判空,如果根节点为空那么返回true,认为就是一颗平衡二叉树。
第二步:编写一个方法来计算整个树的高度
四、代码演示
class Solution {
public boolean isBalanced(TreeNode root) {
if(root==null){
return true;
}
//调用方法,获取左右子树的高度值
int left = getDepth(root.left);
int right = getDepth(root.right);
//这里也是一个递归调用,除了满足条件一,条件二通过调用自身方法isBalance来判断是否左右子树也为平衡二叉树
return Math.abs(left-right)<=1 &&
isBalanced(root.left) &&
isBalanced(root.right);
}
//计算树中节点的高度
public int getDepth(TreeNode root){
if(root==null){
return 0;
}
//递归调用结算左右子树的高度
return Math.max(getDepth(root.left),getDepth(root.right))+1;
}
}