zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 110 平衡二叉树

    110. 平衡二叉树

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

    本题中,一棵高度平衡二叉树定义为:

    一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1。

    示例 1:

    给定二叉树 [3,9,20,null,null,15,7]

        3
       / 
      9  20
        /  
       15   7
    

    返回 true 。

    示例 2:

    给定二叉树 [1,2,2,3,3,null,null,4,4]

           1
          / 
         2   2
        / 
       3   3
      / 
     4   4
    

    返回 false 。

    PS:

    模版一共三步,就是递归的三部曲:
    找终止条件:什么时候递归到头了?此题自然是root为空的时候,空树当然是平衡的。
    思考返回值,每一级递归应该向上返回什么信息?参考我代码中的注释。
    单步操作应该怎么写?因为递归就是大量的调用自身的重复操作,因此从宏观上考虑,只用想想单步怎么写就行了,左树和右树应该看成一个整体,即此时树一共三个节点:root,root.left,root.right。

     
    class Solution {
         //这个ReturnNode是参考我描述的递归套路的第二步:思考返回值是什么
        //一棵树是BST等价于它的左、右俩子树都是BST且俩子树高度差不超过1
        //因此我认为返回值应该包含当前树是否是BST和当前树的高度这两个信息
        private class ReturnNode{
            boolean isB;
            int depth;
            public ReturnNode(int depth, boolean isB){
                this.isB = isB;
                this.depth = depth;
            }
        }
        //主函数
        public boolean isBalanced(TreeNode root) {
            return isBST(root).isB;
        }
        //参考递归套路的第三部:描述单次执行过程是什么样的
        //这里的单次执行过程具体如下:
        //是否终止?->没终止的话,判断是否满足不平衡的三个条件->返回值
        public ReturnNode isBST(TreeNode root){
            if(root == null){
                return new ReturnNode(0, true);
            }
            //不平衡的情况有3种:左树不平衡、右树不平衡、左树和右树差的绝对值大于1
            ReturnNode left = isBST(root.left);
            ReturnNode right = isBST(root.right);
            if(left.isB == false || right.isB == false){
                return new ReturnNode(0, false); 
            }
            if(Math.abs(left.depth - right.depth) > 1){
                return new ReturnNode(0, false);
            }
            //不满足上面3种情况,说明平衡了,树的深度为左右俩子树最大深度+1
            return new ReturnNode(Math.max(left.depth, right.depth) + 1, true);
        }
    }
    
  • 相关阅读:
    HDU----(4291)A Short problem(快速矩阵幂)
    HDU----(2157)How many ways??(快速矩阵幂)
    hdu---(2604)Queuing(矩阵快速幂)
    hdu---(5038)Grade(胡搞)
    齐次方程到矩阵(番外篇)
    uva--1339
    hdu----(5023)A Corrupt Mayor's Performance Art(线段树区间更新以及区间查询)
    hdu----(2848)Repository(trie树变形)
    hdu---(1800)Flying to the Mars(trie树)
    hdu----(1075)What Are You Talking About(trie之查找)
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13076190.html
Copyright © 2011-2022 走看看