当前位置: 首页 > article >正文

平衡二叉树(力扣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;
        }
    }
};


http://www.kler.cn/a/516505.html

相关文章:

  • Moretl FileSync增量文件采集工具
  • 麒麟操作系统服务架构保姆级教程(十四)iptables防火墙四表五链和防火墙应用案例
  • arcgis短整型变为长整型的处理方式
  • 双指针+前缀和习题(一步步讲解)
  • OpenCV相机标定与3D重建(65)对图像点进行去畸变处理函数undistortPoints()的使用
  • 学到一些小知识关于Maven 与 logback 与 jpa 日志
  • 【数据分析】基础篇
  • 基于AnolisOS 8.6安装GmSSL 3.1.1及easy_gmssl库测试国密算法
  • cuda的并行运算介绍
  • python+playwright自动化测试(四):元素操作(键盘鼠标事件)、文件上传
  • 把markdown转换为pdf的方法
  • AI引领工业制造智能化革命:机器视觉与时序数据预测的双重驱动
  • 工业“MCU+AI”
  • 企业智能文档助手方案
  • SpringCloudAlibaba 服务保护 Sentinel 项目集成实践
  • strdup 函数
  • 字符串重新排列
  • C22.【C++ Cont】位运算总结(1)(例题五种解法!含汇编解法)
  • 【运维】什么是Prometheus普罗米修斯?组件式开发
  • 放弃使用Dockerfiles 平替 docker init
  • 【Block总结】FreqFusion特征融合模块,适用于分割、检测任务|即插即用
  • Kafka面试题----Kafka消息是采用Pull模式,还是Push模式
  • Python 在Word中添加、或删除超链接
  • 机器人奇点:从宇树科技看2025具身智能发展
  • 如何将pdf文件中的指定页提取出来,另存为新的pdf文件
  • 【C】链表算法题4 -- 合并两个有序链表