当前位置: 首页 > news >正文

LeetCode-100.相同的树

题目:
难度: 简单
知识点: 二叉树的 深度遍历DFS 和 广度遍历BFS

给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
输入:p = [1,2,3], q = [1,2,3]
输出:true
输入:p = [1,2], q = [1,null,2]
输出:false

解法1:

  • p 和 q 都为 null 的时候 相同
  • p 和 q 只有一个为null 一定不相同
  • 用递归比较两棵树的左子树和右子树,
  • 有左子树并且值相同则左子树相同,
  • 有右子树并且值相同则右子树相同
/*** Definition for a binary tree node.* class TreeNode {*     val: number*     left: TreeNode | null*     right: TreeNode | null*     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {*         this.val = (val===undefined ? 0 : val)*         this.left = (left===undefined ? null : left)*         this.right = (right===undefined ? null : right)*     }* }*/function isSameTree(p: TreeNode | null, q: TreeNode | null): boolean {if(p == null && q == null) return true // p 和 q 都为 null 的时候 相同else if(p == null || q == null) return false // p 和 q 只有一个为null 一定不相同else if(p.val !== q.val) return falseelse return isSameTree(p.left,q.left) &&   isSameTree(p.right,q.right) 
};

解法2:

  • p 和 q 都为 null 的时候 相同
  • p 和 q 只有一个为null 一定不相同
  • 使用 BFS 的方法来判断是否相同是相同树
  • 当元素出队列时,判断值是否相同,不相同则直接return fasle
  • 元素的左孩子入队列的时候,p和q一个为null 另一个不为null return fasle
  • 元素的右孩子入队列的时候,p和q一个为null 另一个不为null return fasle
  • 元素的左孩子右孩子不为null则入队列
  • 最后 两个队列,有一个队列不为空的时候直接return fasle
/*** Definition for a binary tree node.* class TreeNode {*     val: number*     left: TreeNode | null*     right: TreeNode | null*     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {*         this.val = (val===undefined ? 0 : val)*         this.left = (left===undefined ? null : left)*         this.right = (right===undefined ? null : right)*     }* }*/function isSameTree(p: TreeNode | null, q: TreeNode | null): boolean {if(p == null && q == null) return trueelse if(p == null || q == null) return falselet pQueue = [],qQueue = []pQueue.push(p)qQueue.push(q)while(pQueue.length){let pNode = pQueue.shift()let qNode = qQueue.shift()if(pNode?.val != qNode?.val ) return false// 一个为null,另一个不为null 就不相同// 相当于java种的这种写法// if (left1 == null ^ left2 == null) {//     return false;// }// // A ^ B 的结果:// - 如果 A 和 B 相同(都为true或都为false),结果为 false// - 如果 A 和 B 不同(一个true一个false),结果为 trueif((pNode.left == null) != (qNode.left == null)) return falseif((pNode.right == null) != (qNode.right == null)) return falseif(pNode.left) pQueue.push(pNode.left) if(pNode.right) pQueue.push(pNode.right)if(qNode.left) qQueue.push(qNode.left)if(qNode.right) qQueue.push(qNode.right)}return pQueue.length == 0 && qQueue.length == 0};
http://www.gsyq.cn/news/10350.html

相关文章:

  • ubuntu安装minio并切换数据存储目录
  • 数据全生命周期安全解决方案推荐(2025):以全链路泛监测补强控制面,走通“观测先行—证据回灌—渐进加固”的落地路径
  • Java 语法糖大揭秘:让代码更甜更高效的幕后功臣 - 教程
  • 关于OpenCV无法进行h264视频转码的问题 - 实践
  • 树上莫队
  • 比余额宝收益高的低风险短期理财工具-银行同业存单
  • AT_arc122_e [ARC122E] Increasing LCMs
  • C++ 锁
  • 飞书对程序员下手了,0 代码生成各类系统!!(附保姆级项目实战教程)
  • 国标GB28181软件EasyGBS网页直播平台在邮政快递场景的落地与应用
  • PHP资料
  • Shell 脚本编程:函数 - 实践
  • PR曲线绘制
  • 5台电脑怎么同步文件最安全高效?别再只知道用局域网共享了!
  • GPU0与GPU1
  • centos安装docker和Jenkins
  • 硬件检测神器 HWiNFO:全组件监控 + 多系统兼容,免费无广告,运维 / 评测必备
  • 基于 AI 网关提升大模型应用可用性的实践
  • P13617 [ICPC 2025 APC] Bit Counting Sequenc
  • Day 02 HTML的基础 - 教程
  • P3959 [NOIP 2017 提高组] 宝藏 题解
  • java 框架mybatis_01(
  • 扣子Coze智能体实战:自动采集1000条小红书爆款笔记 ,自动写入飞书多维表格
  • 【CVCVCV】dataloader报错RuntimeError: Caught RuntimeError in DataLoader worker process 0
  • 发送一朵云
  • Spring IO工具类及其用法
  • 实用指南:C++编程学习(第34天)
  • Java集合 - 教程
  • .NET 8 内存泄漏分析
  • Spring中@Primary注解的作用及小demo演示