LeetCode中如何解决相同的树问题
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章将为大家详细讲解有关LeetCode中如何解决相同的树问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题目链接https://leetcode-cn.co
千家信息网最后更新 2025年12月02日LeetCode中如何解决相同的树问题
这篇文章将为大家详细讲解有关LeetCode中如何解决相同的树问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
题目链接
https://leetcode-cn.com/problems/same-tree/
题目描述
给定两个二叉树,编写一个函数来检验它们是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
示例 1:
输入: 1 1
/ \ / \
2 3 2 3
[1,2,3], [1,2,3]
输出: true
示例 2:
输入: 1 1
/ \
2 2
[1,2], [1,null,2]
输出: false
示例 3:
输入: 1 1
/ \ / \
2 1 1 2
[1,2,1], [1,1,2]
输出: false
解题方案
思路
标签:深度优先遍历
终止条件与返回值:
当两棵树的当前节点都为null时返回true
当其中一个为null另一个不为null时返回false
当两个都不为空但是值不相等时,返回false
执行过程:当满足终止条件时进行返回,不满足时分别判断左子树和右子树是否相同,其中要注意代码中的短路效应
时间复杂度:O(n),n为树的节点个数
代码
Java版本
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
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)
return false;
return isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
}
}
JavaScript版本
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {TreeNode} p
* @param {TreeNode} q
* @return {boolean}
*/
var isSameTree = function(p, q) {
if(p == null && q == null)
return true;
if(p == null || q == null)
return false;
if(p.val != q.val)
return false;
return isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
};
画解


关于"LeetCode中如何解决相同的树问题"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
相同
两个
示例
篇文章
节点
输入
输出
问题
代码
更多
条件
版本
题目
子树
不错
复杂
实用
个数
内容
函数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
业务流程外贸软件开发
网络安全上市厂家
杭州多家银行软件开发招聘信息
sonolus下服务器地址
服务器怎么设计网卡
深刻认识网络安全的重要意义
php遍历数据库并存储
吉林加工软件开发包括哪些
网络安全防拥塞算法
招行南京分行软件开发岗待遇
松下软件开发大连招聘信息
双网口服务器接两个交换机
数据库同步异步
网络安全人员方面
软件开发在现代科技中的作用
新华互联网科技教育
c 中间件软件开发技术
全球主权财富基金数据库
数据库别名
全球锆石年代学数据库
商店管理系统数据库怎么建表
csgo防止服务器踢出
网络安全学习几个小时
ip网络安全检查表
孝义市网络安全办
网络安全进校园新闻稿文案
vf数据库导入excel方法
女仆日记软件开发
jsp需要web服务器吗
未来旅游业与移动网络技术