题目:
给你两棵二叉树的根节点
p
和q
,编写一个函数来检验这两棵树是否相同。如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
来源:力扣(LeetCode)
链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
示例:
示例 1:
输入:p = [1,2,3], q = [1,2,3]
输出:true
示例 2:
输入:p = [1,2], q = [1,null,2]
输出:false
示例 3:
输入:p = [1,2,1], q = [1,1,2]
输出:false
解法:
广度遍历两棵树,空用"#"表示,判断便利结果是否相等。
知识点:
**1.BFS:**从上到下,从左到右,用队实现。
代码:
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 isSameTree(self, p: Optional[TreeNode], q: Optional[TreeNode]) -> bool: queue_p = [p] result_p = [] while queue_p: cur = queue_p.pop(0) if cur: result_p.append(cur.val) queue_p.append(cur.left) queue_p.append(cur.right) else: result_p.append('#') queue_q = [q] result_q = [] while queue_q: cur = queue_q.pop(0) if cur: result_q.append(cur.val) queue_q.append(cur.left) queue_q.append(cur.right) else: result_q.append('#') return result_p == result_q
力扣:100. 相同的树(Python3)
恽劼恒2023-09-19 17:03
相关推荐
祁思妙想几秒前
10.《滑动窗口篇》---②长度最小的子数组(中等)何大春10 分钟前
【弱监督语义分割】Self-supervised Image-specific Prototype Exploration for WSSS 论文阅读福大大架构师每日一题12 分钟前
文心一言 VS 讯飞星火 VS chatgpt (396)-- 算法导论25.2 1题在下不上天18 分钟前
Flume日志采集系统的部署,实现flume负载均衡,flume故障恢复SEVEN-YEARS22 分钟前
深入理解TensorFlow中的形状处理函数EterNity_TiMe_26 分钟前
【论文复现】(CLIP)文本也能和图像配对机器学习之心37 分钟前
一区北方苍鹰算法优化+创新改进Transformer!NGO-Transformer-LSTM多变量回归预测Suyuoa38 分钟前
附录2-pytorch yolov5目标检测yyt_cdeyyds1 小时前
FIFO和LRU算法实现操作系统中主存管理alphaTao1 小时前
LeetCode 每日一题 2024/11/18-2024/11/24