平衡二叉树(力扣110)

所谓平衡二叉树,就是每一个节点的左右子树的高度差不大于1。而一个子树的高度,就是父节点的最大高度。这道题的思路其实和二叉树的最大深度(力扣104)-CSDN博客有很大的相似之处,都需要将左右子树的高度返回给父节点,因此也是采用后序遍历。大家可以先看一下这篇博客,有助于理解该题。下面我基于你已经看过二叉树的最大深度(力扣104)-CSDN博客,进而讲解一下这道题的思路。

在这道题中,我们返回左右子树的高度的时候,需要比较左右子树的高度,如果子树并不平衡,直接返回-1,并且只要有一个子树不平衡,那么这棵二叉树就是不平衡的,所以我们可以写if语句,一旦检测到左右子树有一个高度为-1,就不断向上返回-1,最终在根节点得到的返回值也为-1,这表示这整个二叉树不平衡。反之,我们返回以该父节点为根节点的子树的高度,最终得到这整个二叉树的高度,这就表示这棵二叉树是平衡的,因为一旦在递归中途但回了-1,最后都不会得到该二叉树的高度。大家可以结合我下面的代码及注释,更容易理解。

代码如下:

复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
   int getHeight(TreeNode* node){
    //深度遍历的终止条件:遍历到空节点终止
      if(node == NULL) return 0;
    //递归左子树
      int height1 = getHeight(node -> left);
    //递归右子树  
      int height2 = getHeight(node -> right);
    //以下为处理逻辑 
      if(height1 == -1) return -1;//检测到左右子树有一个高度为-1,则直接返回-1
      if(height2 == -1) return -1;
      //比较左右子树高度,如果平衡,就返回以该节点为根节点的子树的高度
      if(abs(height1 - height2) <= 1) return max(height1,height2) + 1;//求子树的高度需要取该子树的左右子树中较大的高度
      else return -1;//不平衡就返回-1
   }
    bool isBalanced(TreeNode* root) {
        if(getHeight(root) == -1){
            return false;
        }else{
            return true;
        }
    }
};
相关推荐
立志成为大牛的小牛2 分钟前
数据结构——二十三、并查集的终极优化(王道408)
开发语言·数据结构·笔记·学习·程序人生·考研
珊珊而川17 分钟前
SAUP 算法
算法
.YM.Z20 分钟前
数据结构——链表(二)
数据结构·链表
寂静山林36 分钟前
UVa 1471 Defense Lines
算法
CHANG_THE_WORLD1 小时前
switch语句在汇编层面的几种优化方式 ,为什么能进行优化
汇编·算法·switch·汇编分析·switch case·switch case 汇编·switch case 语句
勇闯逆流河1 小时前
【C++】用红黑树封装map与set
java·开发语言·数据结构·c++
山,离天三尺三1 小时前
深度拷贝详解
开发语言·c++·算法
Blossom.1181 小时前
把AI“撒”进农田:基于极值量化与状态机的1KB边缘灌溉决策树
人工智能·python·深度学习·算法·目标检测·决策树·机器学习
一只鱼^_2 小时前
第 167 场双周赛 / 第 471 场周赛
数据结构·b树·算法·leetcode·深度优先·近邻算法·迭代加深
Seeing52 小时前
数据结构----树
数据结构