leetcode第110题python版平衡二叉树

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    """
    110. 平衡二叉树
    给定一个二叉树,判断它是否是高度平衡的二叉树。
    本题中,一棵高度平衡二叉树定义为:
    一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。
    """
    def isBalanced(self, root: TreeNode) -> bool:
        # 思路:递归,设计个方法,不是平衡树就返回-1,是平衡树就返回树的高度;
        # 平衡树需要满足条件,左右子树都是平衡树,且左右子树高度差不超过1
        return self.check(root) != -1

    def check(self, root: TreeNode) -> int:
        # 1. root为[]时
        if not root: return 0

        # 2. 考虑左子树
        l = self.check(root.left) # 已涵盖root.left == None的情况
        # 左子树不是平衡树的情况
        if l == -1: return -1

        # 3. 考虑右子树
        r = self.check(root.right) # 已涵盖root.right == None的情况
        # 右子树不是平衡树的情况
        if r == -1: return -1

        # 4. 考虑左右子树高度差大于1的情况
        if abs(l-r) > 1: return -1

        # 5. 返回数的高度
        return max(l, r) + 1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ICPunk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值