平衡二叉树(力扣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;
        }
    }
};
相关推荐
Nebula_g10 小时前
C语言应用实例:硕鼠游戏,田忌赛马,搬桌子,活动选择(贪心算法)
c语言·开发语言·学习·算法·游戏·贪心算法·初学者
snakecy11 小时前
信息系统项目管理师--论文case
大数据·学习·职场和发展·区块链
liu****11 小时前
11.Linux进程信号(三)
linux·运维·服务器·数据结构·1024程序员节
AI科技星11 小时前
张祥前统一场论动量公式P=m(C-V)误解解答
开发语言·数据结构·人工智能·经验分享·python·线性代数·算法
海琴烟Sunshine11 小时前
leetcode 345. 反转字符串中的元音字母 python
python·算法·leetcode
geobuilding12 小时前
将大规模shp白模贴图转3dtiles倾斜摄影,并可单体化拾取建筑
算法·3d·智慧城市·数据可视化·贴图
jghhh0112 小时前
基于高斯伪谱法的弹道优化方法及轨迹仿真计算
算法
AnRan080812 小时前
产业投资工作坊: 清洁能源赛道分析与投资实战
职场和发展·能源