判断是否为平衡二叉树

//判断给定的二叉树是否是一棵平衡二叉树
/*
	采用了递归的方式如果是平衡二叉树的话则返回的是树的高度否则返回-1
	只要经过判断后有一个值为-1则代表不是平衡二叉树,最终的结果返回为false
*/
public boolean isBalanced(TreeNode root){
	if(root == null){
		return true;
	}
	return height(root) != -1;
}
public int height(TreeNode root){
	//如果为空则表示返回的高度为0
	if(root == null){
		return 0;
	}
	int lH = height(node.left);
	//表示左子树不是平衡二叉树
	//返回结果就 不是平衡二叉树
	if(lH == -1){
		return -1;
	}
	int rH = height(node.right);
	if(rH == -1){
		return  -1;
	}
	//左右子树的高度差大于1返回结果为-1
	if(lH - rH < -1 || lH - rH > 1){
		return -1;
	}
	//表示返回的是两棵树中的最大值
	return Math.max(lH,rH) + 1;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值