zoukankan      html  css  js  c++  java
  • 110. Balanced Binary Tree

    一、题目

      1、审题

      2、分析

        给出一棵二叉树,判断其是否是一棵二叉平衡树。

    二、解答

      1、思路:

        方法一、

          采用递归;

          每次获取 root 结点的左子树、右子树的高度,比较高度差是否小于等于 1;

          同时判断左子树、右子树是否也是二叉平衡树。

    public boolean isBalanced(TreeNode root) {
            if(root == null)
                return true;
    
            int left = getDepthHelper(root.left);
            int right = getDepthHelper(root.right);
            
            return Math.abs(left -  right) <= 1 && isBalanced(root.left) && isBalanced(root.right);
        }
        
    
        private int getDepthHelper(TreeNode root) {
            if(root == null)
                return 0;
            
            return Math.max(getDepthHelper(root.left), getDepthHelper(root.right)) + 1;
        }

      方法二、

        采用深度优先遍历的方式获取深度,并且获取时比较该节点的子树是否平衡,若不平衡,返回 -1,否则返回高度。

    public boolean isBalanced(TreeNode root) {
            return dfsHeight(root) != -1;
        }
        private int dfsHeight(TreeNode root) {
            if(root == null)
                return 0;
            
            int leftHeight = dfsHeight(root.left);
            if(leftHeight == -1) return -1;
            int rightHeight = dfsHeight(root.right);
            if(rightHeight == -1) return -1;
            
            if(Math.abs(leftHeight - rightHeight) > 1) return -1;
            
            return Math.max(leftHeight, rightHeight) + 1;
        }
  • 相关阅读:
    vue2.0 动画
    I. 对缓存进行处理
    G. 【案例】Ajax实现无刷新分页效果
    H. Ajax对XML信息的接收与处理
    F. 异步同步请求
    D. 接收服务器端返回的信息
    E. 请求GET和POST的不同
    C. 发起对服务器的请求
    B. 创建Ajax对象
    A. AJAX介绍
  • 原文地址:https://www.cnblogs.com/skillking/p/9734889.html
Copyright © 2011-2022 走看看