二叉树?是否相同?
题目:
给定两个二叉树,编写一个函数来检验它们是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
例子:
示例 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
题目分析
二叉树相同
- 结构相同
- 每个结点值相同
如果两颗二叉树相同
对应子树也相同 ==> 递归!
解题思路
变量 | 作用 |
---|---|
p | 二叉树1的根结点 |
q | 二叉树2的根结点 |
过程:
如果
p q 的值不相等 ==> 不是相同的二叉树
p q 的值相等 ==>判断子树是否相同
- 左子树是否相同 (递归)
- 右子树是否相同 (递归)
代码如下
class Solution {
public:
bool isSameTree(TreeNode* p, TreeNode* q) {
if(!p && !q) return true;
if(!p && q) return false;
if(p && !q) return false;
if(p->val != q->val) return false;
else {
if(!isSameTree(p->left,q->left)) return false; //判断左子树是否相同
if(!isSameTree(p->right,q->right)) return false; //判断右子树是否相同
}
return true;
}
};