题目描述:
输入一棵二叉树,判断该二叉树是否是平衡二叉树。
解题思路:
首先定义一个球树深度的函数,首先如果根节点为null,返回true,分别计算左右子树的深度,如果左右子树深度差小于等于1,则递归对根节点的左右子树,否则返回false。
代码(java):
public class Solution {
public boolean IsBalanced_Solution(TreeNode root) {
if(root==null)return true;
int leftDepth=treeDepth(root.left);
int rightDepth=treeDepth(root.right);
if(Math.abs(leftDepth-rightDepth)<=1){
return IsBalanced_Solution(root.left) && IsBalanced_Solution(root.right);
}
return false;
}
public int treeDepth(TreeNode root){
if(root==null)return 0;
return Math.max(treeDepth(root.right),treeDepth(root.left))+1;
}
}