平衡二叉树的判断
输入一棵二叉树,判断该二叉树是否是平衡二叉树。
平衡二叉树左右子树深度只差不超过1.
public class Solution { private boolean isAVL = true; public boolean IsBalanced_Solution(TreeNode root) { if (root == null) return true; depth(root); return isAVL; } public int depth(TreeNode root) { if (root == null) return 0; int leftDepth = depth(root.left); int rightDepth = depth(root.right); if (leftDepth - rightDepth > 1 || leftDepth - rightDepth < -1) { isAVL = false; } return leftDepth>rightDepth ? leftDepth+1:rightDepth+1; } }
作者:Pickle
声明:对于转载分享我是没有意见的,出于对博客园社区和作者的尊重一定要保留原文地址哈。
致读者:坚持写博客不容易,写高质量博客更难,我也在不断的学习和进步,希望和所有同路人一道用技术来改变生活。觉得有点用就点个赞哈。