判断两棵二叉树是否相同
给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。
- 二叉树具有递归的特性
- 若两棵二叉树是相同的,那么它们的根节点一定是相同的
- 在第2步的基础上,若根节点的左右子树也都是相同的,那么这两棵二叉树就相同
从第2步到第3步,具有“重叠子空间”。
public boolean isSameTree(TreeNode p, TreeNode q) {
if(p==null && q==null){
//递归退出条件, 遍历到叶子节点 还是一样的
return true;
}
if(p==null || q==null){
//递归退出条件,遍历到叶子节点后,有一个节点空,另一个不空
return false;
}
if(p.val != q.val){
//递归遍历到 子树, 子树的根节点 value 不一样. 说明 两棵树不相同
return false;
}
//子树的根节点一样, 继续判断: 它们的左右子树是否一样
return isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
2016-07-22 内存分配与内存管理的一些理解