leetcode 平衡高度二叉树/** * Definition for a binary tree node. * public class TreeNode { * int val;

旧街凉风 提交于 2020-02-06 16:39:39

思路:前提会 计算二叉树最大深度(在计算二叉树最大深度的时候,就是采用递归的方法,取左右子树的最大);

所以稍加改造,在每次计算左右子树的最大深度之后,加一个if ,判断是否满足,绝对值之差不超过1,如果不满足,就赋值给一个flag

private boolean result = true;

public boolean isBalanced(TreeNode root) {
    maxDepth(root);
    return result;
}

public int maxDepth(TreeNode root) {
    if (root == null) return 0;
    int l = maxDepth(root.left);
    int r = maxDepth(root.right);
    if (Math.abs(l - r) > 1) result = false;
    return 1 + Math.max(l, r);
}

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!