《剑指offer》刷题系列——(二十八) 平衡二叉树

16 篇文章 0 订阅
16 篇文章 0 订阅

题目

输入一棵二叉树的根节点,判断该树是不是平衡二叉树。如果某二叉树中任意节点的左右子树的深度相差不超过1,那么它就是一棵平衡二叉树。
在这里插入图片描述

思路

在上一题求 二叉树的深度 中,我们已经掌握了求一棵树深度的方法,因此本题可以利用求深度的方法。
对二叉树做后序遍历从底至顶返回子树深度,若判定某子树不是平衡树则 “剪枝” ,直接向上返回。

代码

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def isBalanced(self, root: TreeNode) -> bool:
        return self.deep(root)>=0

    def deep(self,root):
        # 如果根节点为空,深度为0
        if not root:
            return 0
        ## 当当前树不平衡时,返回-1
        # 求左子树的深度,如果返回值为-1,说明不平衡,返回
        leftdeep = self.deep(root.left)
        if leftdeep == -1: return -1
        # 求右子树的深度,如果返回值为-1,说明不平衡,返回
        rightdeep = self.deep(root.right)
        if rightdeep == -1: return -1
        ## 如果左右子树深度差的绝对值大于1,就返回-1,表示当前树不平衡
        if abs(leftdeep-rightdeep)>1: return -1
        ## 返回当前树的深度(左右子树深度的最大值加1)
        return max(leftdeep, rightdeep)+1

复杂度

时间复杂度 O(N): N为树的节点数;最差情况下,需要递归遍历树的所有节点。
空间复杂度 O(N): 最差情况下(树退化为链表时),系统递归需要使用 O(N) 的栈空间。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值