平衡二叉树(力扣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;
        }
    }
};
相关推荐
好好研究20 分钟前
学习栈和队列的插入和删除操作
数据结构·学习
YuTaoShao1 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
生态遥感监测笔记1 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
Tony沈哲2 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东2 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习
pumpkin845143 小时前
Rust 调用 C 函数的 FFI
c语言·算法·rust
挺菜的3 小时前
【算法刷题记录(简单题)003】统计大写字母个数(java代码实现)
java·数据结构·算法
mit6.8243 小时前
7.6 优先队列| dijkstra | hash | rust
算法
2401_858286114 小时前
125.【C语言】数据结构之归并排序递归解法
c语言·开发语言·数据结构·算法·排序算法·归并排序
guygg884 小时前
基于matlab的FIR滤波器
开发语言·算法·matlab