【Python刷题】对称二叉树

问题描述

给你一个二叉树的根节点 root , 检查它是否轴对称。

示例 1:

python 复制代码
输入:root = [1,2,2,3,4,4,3]
输出:true

示例 2:

python 复制代码
输入:root = [1,2,2,null,3,null,3]
输出:false

解决办法

  • 使用双向队列的方法,首先导入deque库
python 复制代码
from collections import deque
  • 判断root,如果 root 为空,返回 True
  • 定义一个dq队列,刚开始放 root 的左右结点,开始遍历。队列的特点是先进先出,所以依次放入左结点和右结点:
python 复制代码
left_node=dq.popleft()
right_node=dq.popleft()
  • 判断:如果左结点和右结点都不存在,跳出本次循环,继续往下遍历。
  • 如果左结点在,右结点不在。或者左结点不在,右结点在。又或者左结点的值不等于右结点的值,则不是对称二叉树,返回False。
  • 除以上情况外,令左子树的左结点、右子树的右结点、左子树的右结点、右子树的左结点一次入队,继续遍历。

代码示例

python 复制代码
from collections import deque
class Solution:
    def isSymmetric(self, root: Optional[TreeNode]) -> bool:
        if root is None:
            return True
        dq=deque([root.left,root.right])
        while dq:
            left_node=dq.popleft()
            right_node=dq.popleft()
            if not left_node and not right_node:
                continue
            if not left_node or not right_node or left_node.val!=right_node.val:
                return False
            dq.append(left_node.left)
            dq.append(right_node.right)
            dq.append(left_node.right)
            dq.append(right_node.left)
        return True
相关推荐
!停6 分钟前
C++入门—初阶模板
开发语言·c++
so2F32hj27 分钟前
拆解 OpenHands(14)--- Microagents
java·开发语言
Jp7gnUWcI21 分钟前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
开发语言·c++
北顾笙98022 分钟前
day15-数据结构力扣
数据结构·算法·leetcode
xcs1940540 分钟前
Java 上位机防空警报系统开发
java·开发语言
Ulyanov41 分钟前
卡尔曼滤波技术博客系列:第四篇:多目标跟踪:数据关联与航迹管理
python·目标跟踪·系统仿真·雷达电子战·仿真引擎
AI成长日志42 分钟前
【GitHub开源项目专栏】黑客松项目架构模式解析:微服务、事件驱动与Serverless实战
算法
人道领域42 分钟前
【LeetCode刷题日记:24】两两交换链表
算法·leetcode·链表
北顾笙9801 小时前
day16-数据结构力扣
数据结构·算法·leetcode
追光的蜗牛丿1 小时前
C++中引用与指针的选择
开发语言·c++