给定两个二叉树,编写一个函数来检验它们是否相同。
如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。
示例 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
https://leetcode-cn.com/problems/same-tree/description/
判断两个树是否相等用递归来解决
两个树要相等:
(1)根节点相等
(2)左子树相等
1>根节点 2>左子树 3>右子树
……
(3)右子树相等
1>根节点 2>左子树 3>右子树
……
实现
/**
* 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;
//一个为空
if(p == NULL || q == NULL)
return false;
//1. 节点的值是否相等 2.左子树是否相等 3.右子树是否相等
return p->val == q->val
&& isSameTree(p->left, q->left)
&& isSameTree(p->right, q->right);
}