You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
|
package class07;
|
|
|
|
|
|
|
|
|
|
// 测试链接:https://leetcode.com/problems/balanced-binary-tree
|
|
|
|
|
public class Code02_BalancedBinaryTree {
|
|
|
|
|
|
|
|
|
|
public static class TreeNode {
|
|
|
|
|
public int val;
|
|
|
|
|
public TreeNode left;
|
|
|
|
|
public TreeNode right;
|
|
|
|
|
|
|
|
|
|
TreeNode(int val) {
|
|
|
|
|
this.val = val;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static class Info {
|
|
|
|
|
public boolean isBalanced;
|
|
|
|
|
public int height;
|
|
|
|
|
|
|
|
|
|
public Info(boolean i, int h) {
|
|
|
|
|
isBalanced = i;
|
|
|
|
|
height = h;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static boolean isBalanced(TreeNode root) {
|
|
|
|
|
return process(root).isBalanced;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static Info process(TreeNode root) {
|
|
|
|
|
if (root == null) {
|
|
|
|
|
return new Info(true, 0);
|
|
|
|
|
}
|
|
|
|
|
Info leftInfo = process(root.left);
|
|
|
|
|
Info rightInfo = process(root.right);
|
|
|
|
|
int height = Math.max(leftInfo.height, rightInfo.height) + 1;
|
|
|
|
|
boolean isBalanced = leftInfo.isBalanced && rightInfo.isBalanced
|
|
|
|
|
&& Math.abs(leftInfo.height - rightInfo.height) < 2;
|
|
|
|
|
return new Info(isBalanced, height);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|