leetcode 110

110: 平衡二叉树

平衡二叉树 是指该树所有节点的左右子树的高度相差不超过 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:
    bool isBalanced(TreeNode* root) {
        auto recur=[&](this auto&& recur,TreeNode* node)->int{
            if(node==nullptr) return 0;
            int left=recur(node->left);
            if(left==-1) return -1;
            int right=recur(node->right);
            if(right==-1) return -1;
            return abs(left-right)<=1 ? max(left,right)+1:-1;
        };

        return recur(root)!=-1;
    }
};
相关推荐
_深海凉_6 分钟前
LeetCode热题100-颜色分类
python·算法·leetcode
网安INF19 分钟前
数据结构第三章:栈、队列和数组
数据结构
hetao173383740 分钟前
2026-04-09~12 hetao1733837 的刷题记录
c++·算法
6Hzlia41 分钟前
【Hot 100 刷题计划】 LeetCode 136. 只出现一次的数字 | C++ 哈希表&异或基础解法
c++·算法·leetcode
MWWZ1 小时前
最近的一些软件更新
opencv·算法·计算机视觉
CoovallyAIHub1 小时前
视频理解新范式:Agent不再被动看视频,LensWalk让它自己决定看哪里
算法·架构·github
CoovallyAIHub1 小时前
斯坦福丨AirVLA:将地面机械臂模型迁移至无人机实现空中抓取,成功率从23%提升至50%
算法·架构·github
yuannl102 小时前
数据结构----双端队列实现
数据结构
无限进步_2 小时前
【C++】只出现一次的数字 II:位运算的三种解法深度解析
数据结构·c++·ide·windows·git·算法·leetcode
Takoony2 小时前
GPU 推理并发的本质:从第一性原理到工程实践
算法·gru