LeetCode110:平衡二叉树

题目描述

给定一个二叉树,判断它是否是 平衡二叉树


解题思想

使用递归依次计算左子树的高度和右子树的高度

代码

cpp 复制代码
class Solution {
public:
    int height(TreeNode* node) {
        if (node == nullptr) return 0;
        
        int leftT = height(node->left);
        if (leftT == -1) return -1;
        int rightT = height(node->right);
        if (rightT == -1) return -1;
        
        if (abs(leftT - rightT) > 1) 
            return -1;

        else
            return 1 + max(leftT, rightT);
    }


    bool isBalanced(TreeNode* root) {
        return height(root) == -1 ? false : true;
    }
};
相关推荐
wearegogog1231 天前
光谱分析波段选择的连续投影算法
算法
执笔论英雄1 天前
【RL】DAPO 数据处理
算法
why1511 天前
面经整理——算法
java·数据结构·算法
悦悦子a啊1 天前
将学生管理系统改造为C/S模式 - 开发过程报告
java·开发语言·算法
痕忆丶1 天前
双线性插值缩放算法详解
算法
_codemonster1 天前
深度学习实战(基于pytroch)系列(四十八)AdaGrad优化算法
人工智能·深度学习·算法
鹿角片ljp1 天前
力扣140.快慢指针法求解链表倒数第K个节点
算法·leetcode·链表
自由生长20241 天前
位运算第1篇-异或运算-快速找出重复数字
算法
xxxxxmy1 天前
同向双指针(滑动窗口)
python·算法·滑动窗口·同向双指针
释怀°Believe1 天前
Daily算法刷题【面试经典150题-5️⃣图】
算法·面试·深度优先