写一个函数,用来判断一颗二叉树是否对称

写一个函数,用来判断一颗二叉树是否对称。

如果一颗二叉树和它的镜像是相同的,那么它是对称的。
对称可以理解为,以根节点所在的竖直线为对称轴,二叉树的左右两边轴对称。

**
结束条件:
注意:isSym函数,仅需要一个参数proot
1.若二叉树为空,返回True
注意:isMrr函数,需要两个参数proot.left,proot.right
2.若二叉树仅有一个节点,即根节点(也即叶节点),返回True
3.若二叉树的left和right存在且相等,继续比较左-左与右-右,以及左-右与右-左,即返回isMrr(left.left,right.right) and isMrr(left.right,right.left)
4.其他情况,返回False
**
下面展示完整的代码

class TreeNode:
    def __init__(self, value):
        self.val = value
        self.left = None
        self.right = None


#判断对称二叉树
def isSym(self, proot):
    #若二叉树不存在,返回True
    if not proot:
        return True
    return isMrr(proot.left,proot.right)
#判断左子树、右子树是否相同
def isMrr(left, right):
    #若二叉树中仅有一个节点,即根节点是叶节点,返回True
    if left is None and right is None:
        return True
    #若左右节点存在且相同,继续判断左-左和右-右,以及左-右和右-左
    elif left and right and left.val == right.val:
        return isMrr(left.left, right.right) and isMrr(left.right, right.left)
    else:
        return False

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值