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

LeetCode 110.平衡二叉树 (C++)

题目地址:力扣

平衡二叉树,指的就是每个节点的左右子树高度相差不超过1的树

解法1:从上往下

思路:首先需要知道左子树和右子树的高度,那么可以定义一个depth函数求高度,要求高度那么很显然是递归函数,从上向下找到最高的再返回上来。总的判断二叉树平衡又需要满足三个条件:

1、当前节点是平衡的

2、当前节点的左子树是平衡的

3、当前节点的右子树是平衡的

因此判断是否平衡的函数也是一个递归函数。

这种解法容易想到,但是有一个问题在于很多操作都重复求了同一个节点的高度,因此这种方法的时间复杂度较高。

class Solution {
public:
    // depth函数用于返回当前节点的深度
    int depth(TreeNode *root)
    {
        if (root == nullptr)
            return 0;
        else
            return max(depth(root->left), depth(root->right)) + 1;
    }

    
    bool isBalanced(TreeNode* root) {
        // 若当前节点为空,则必平衡
        if (root == nullptr)
            return true;
        // 若当前节点不为空,那么要验证三个东西
        // 1.当前节点是平衡的
        // 2.当前节点的左子树是平衡的
        // 3.当前节点的右子树是平衡的
        else
            return abs(depth(root->left) - depth(root->right) <= 1) && isBalanced(root->left) && isBalanced(root->right);
    }
};

解法2:从下往上

思路:从下往上判断,如果下面的某个节点不满足平衡二叉树的定义,那么这棵树必然不满足定义,因此我们需要从下往上找,那么这也决定了depth函数必然是递归的。

但是这个递归要做两件事情

1、如果左右子树都满足平衡,那么需要返回当前节点的最大深度给上一个节点

2、如果左右子树有一者不满足,就将不满足的信息一直传递给最外层的节点

class Solution {
public:
    int depth(TreeNode* root)
    {
        // 空节点高度为0
        if (root == nullptr)
            return 0; 
        // 左子树深度和右子树深度
        int leftDepth = depth(root->left);
        int rightDepth = depth(root->right);

        // 如果左右子树其一不满足平衡情况,则直接传递-1给上层
        if (leftDepth == -1 || rightDepth == -1)
            return -1;
        else
        // 左右子树满足,则判断当前节点是否满足平衡,若满足返回当前节点最大深度,不满足则返回-1
            if (abs(leftDepth - rightDepth) <= 1)
                return max(leftDepth, rightDepth) + 1;
            else
                return -1;
    }
    
    bool isBalanced(TreeNode* root) {
        // 只需要判断结果是否是-1即可
        if (depth(root) != -1)
            return true;
        else
            return false;
    }
};

Accepted

  • 228/228 cases passed (12 ms)
  • Your runtime beats 53.73 % of cpp submissions
  • Your memory usage beats 78.32 % of cpp submissions (20.3 MB)

相关文章:

  • 基于SpringBoot的校园闲置物品交易管理系统
  • 在线表格 循环替换 脚本
  • 量化投资学习——股指期货研究(二)
  • npm下载包速度慢-淘宝NPM镜像服务器--如何切换其他服务器下载
  • 基于elasticjob的入门maven项目搭建
  • 【校招VIP】产品项目分析之竞品分析
  • 服务端(后端)主动通知前端的实现:WebSocket(springboot中使用WebSocket案例)
  • 计算机毕业设计django基于python教学互动系统(源码+系统+mysql数据库+Lw文档)
  • 2022深圳xxx校招Java笔试题目(选择题+简答题)
  • 神经网络训练电脑配置,cpu可以训练神经网络吗
  • RFID读写器的功能
  • 神经元在人体内如何分布,人体神经元怎么分布的
  • Java基础:通过Callable创建多线程
  • 音视频封装格式:MPTG2-TS
  • Tlsr8258开发-修改蓝牙hid mouse
  • Babel配置的不完全指南
  • JavaScript类型识别
  • leetcode讲解--894. All Possible Full Binary Trees
  • linux学习笔记
  • node 版本过低
  • PHP的Ev教程三(Periodic watcher)
  • PHP那些事儿
  • Python socket服务器端、客户端传送信息
  • 少走弯路,给Java 1~5 年程序员的建议
  • 实现菜单下拉伸展折叠效果demo
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 智能合约开发环境搭建及Hello World合约
  • 最简单的无缝轮播
  • 白色的风信子
  • 《码出高效》学习笔记与书中错误记录
  • 2017年360最后一道编程题
  • ​创新驱动,边缘计算领袖:亚马逊云科技海外服务器服务再进化
  • ​用户画像从0到100的构建思路
  • ###51单片机学习(2)-----如何通过C语言运用延时函数设计LED流水灯
  • #控制台大学课堂点名问题_课堂随机点名
  • #我与Java虚拟机的故事#连载07:我放弃了对JVM的进一步学习
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (C语言)字符分类函数
  • (Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (区间dp) (经典例题) 石子合并
  • (转)编辑寄语:因为爱心,所以美丽
  • .net6Api后台+uniapp导出Excel
  • .netcore 如何获取系统中所有session_ASP.NET Core如何解决分布式Session一致性问题
  • @manytomany 保存后数据被删除_[Windows] 数据恢复软件RStudio v8.14.179675 便携特别版...
  • [2016.7.Test1] T1 三进制异或
  • [AI]ChatGPT4 与 ChatGPT3.5 区别有多大
  • [AutoSar]BSW_OS 01 priority ceiling protocol(PCP)
  • [BROADCASTING]tensor的扩散机制
  • [C#]winform制作仪表盘好用的表盘控件和使用方法
  • [C#C++]类CLASS
  • [codevs 1288] 埃及分数 [IDdfs 迭代加深搜索 ]
  • [dfs搜索寻找矩阵中最长递减序列]魔法森林的秘密路径
  • [flink总结]什么是flink背压 ,有什么危害? 如何解决flink背压?flink如何保证端到端一致性?