给你两棵二叉树的根节点 p
和 q
,编写一个函数来检验这两棵树是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
提示:
- 两棵树上的节点数目都在范围
[0, 100]
内 -10的4次方 <= Node.val <= 10的4次方
解题思路:先判断两个树是否都为空,若为空则两个树相等;若一个为空一个不为空,则必不相等;若都不为空,依次判断对应的第一个值是否相等,若不相等直接返回false;若相等接着往后继续判断即可
代码:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
bool isSameTree(struct TreeNode* p, struct TreeNode* q) {
if (p == NULL && q == NULL) {
return true;
} else if (p == NULL || q == NULL) {
return false;
} else if (p->val != q->val) {
return false;
} else {
return isSameTree(p->left, q->left) && isSameTree(p->right, q->right);
}
}