【数据结构--二叉树】平衡二叉树

题目描述:

代码实现:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
int TreeHeight(struct TreeNode* root)
{
    if(root==NULL)
        return 0;
    //左右子树中大的那个+1
    int left=TreeHeight(root->left);
    int right=TreeHeight(root->right);
    return left>right?left+1:right+1;
}
bool isBalanced(struct TreeNode* root){
    if(root==NULL)
        return true;
    int left=TreeHeight(root->left);
    int right=TreeHeight(root->right);
    if(left-right>1||right-left>1)
    {
        return false;
    }
    return isBalanced(root->left)&&isBalanced(root->right);
}
相关推荐
hans汉斯14 小时前
基于改进YOLOv11n的无人机红外目标检测算法
大数据·数据库·人工智能·算法·yolo·目标检测·无人机
理人综艺好会14 小时前
redis学习之基础数据结构
数据结构·redis·学习
星轨初途14 小时前
数据结构二叉树之链式结构(3)(下)
c语言·网络·数据结构·经验分享·笔记·后端
valan liya14 小时前
C++list
开发语言·数据结构·c++·list
Swift社区14 小时前
LeetCode 431 - 将 N 叉树编码成二叉树
算法·leetcode·职场和发展
小毅&Nora14 小时前
【后端】【C++】智能指针详解:从裸指针到 RAII 的优雅演进(附 5 个可运行示例)
c++·指针
fashion 道格14 小时前
深入理解数据结构:单链表的 C 语言实现与应用
c语言·数据结构
子一!!14 小时前
数据结构===Map/Set (2)===
数据结构
万粉变现经纪人14 小时前
如何解决 pip install 编译报错 ‘cl.exe’ not found(缺少 VS C++ 工具集)问题
开发语言·c++·人工智能·python·pycharm·bug·pip
子豪-中国机器人14 小时前
1030-csp 2019 入门级第一轮
算法