数据结构与算法二叉树——平衡二叉树

Posted buptleida

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据结构与算法二叉树——平衡二叉树相关的知识,希望对你有一定的参考价值。

平衡二叉树

LeetCode:平衡二叉

题目描述:

给定一个二叉树,判断它是否是高度平衡的二叉树。

示例:

给定二叉树 [3,9,20,null,null,15,7]
    3
   /   9  20
    /     15   7
返回true

思想:

使用实例域变量记录是否与有不满足平衡的节点出现,使用一次递归即可。

代码

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    private boolean flag = true;
    //返回高度,并且在递归过程中记录flag
    private int treeDepth(TreeNode root){
        if(root ==null)
            return 0;
        int leftLen = treeDepth(root.left);
        int rightLen = treeDepth(root.right);
        if(Math.abs(leftLen-rightLen)>1)
            flag = false;
        return Math.max(leftLen,rightLen)+1;
    }
    public boolean isBalanced(TreeNode root) {
        int i = treeDepth(root);
        return flag;
    }
}

以上是关于数据结构与算法二叉树——平衡二叉树的主要内容,如果未能解决你的问题,请参考以下文章

平衡二叉树算法时间复杂度分析与优点

数据结构与算法之深入解析“平衡二叉树”的求解思路与算法示例

平衡二叉树的算法

数据结构与算法系列研究五——树二叉树三叉树平衡排序二叉树AVL

数据结构与算法简记--红黑树

什么是《平衡二叉树》