力扣刷题笔记:101、对称二叉树(队列queue,很容易理解的代码、完整题解代码及注释)

题目:

101、对称二叉树

给定一个二叉树,检查它是否是镜像对称的。

例如,二叉树 [1,2,2,3,4,4,3] 是对称的。

在这里插入图片描述

但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的:

在这里插入图片描述

题解思路:

BFS 使用一个队列,很多题解中的 BFS 都是放入了四次节点,一种更直观的做法是两两一组放入队列中。

在队列中同时取出两个节点left, right,判断这两个节点的值是否相等,然后把他们的孩子中按照(left.left, right.right) 一组,(left.right, right.left)一组放入队列中。

BFS做法需要把所有的节点都检查完才能确定返回结果True,除非提前遇到不同的节点值而终止返回False。

题解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:
    def isSymmetric(self, root: TreeNode) -> bool:
        queue = collections.deque()
        queue.append((root, root))
        while queue:
            left, right = queue.popleft()
            if not left and not right:
                continue
            if not left or not right:
                return False
            if left.val != right.val:
                return False
            queue.append((left.left, right.right))
            queue.append((left.right, right.left))
            # print(queue)
        return True

在这里插入图片描述

作者:fuxuemingzhu
链接:https://leetcode-cn.com/problems/symmetric-tree/solution/bfs-dui-lie-tong-shi-bao-cun-bao-cun-yao-pan-duan-/
来源:力扣(LeetCode)https://leetcode-cn.com/problems/symmetric-tree/

扫描二维码关注公众号,回复: 12669303 查看本文章

猜你喜欢

转载自blog.csdn.net/weixin_44414948/article/details/113748957