剑指 Offer 28. 对称的二叉树
一、题目
请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。
二、思路
考虑从顶至底递归,判断每对节点是否对称,从而判断树是否为对称二叉树。
三、代码
class Solution: def isSymmetric(self, root: TreeNode) -> bool: def recur(L, R): if not L and not R: return True if not L or not R or L.val != R.val: return False return recur(L.left, R.right) and recur(L.right, R.left) return recur(root.left, root.right) if root else True
四、分析
复杂度分析:
时间复杂度 O(N) : 其中 N为二叉树的节点数量,每次执行 recur() 可以判断一对节点是否对称,因此最多调用 N/2次 recur() 方法。
空间复杂度 O(N): 最差情况下,二叉树退化为链表,系统使用 O(N) 大小的栈空间。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了