给定两个非空二叉树 s 和 t,检验 s 中是否包含和 t 具有相同结构和节点值的子树。s 的一个子树包括 s 的一个节点和这个节点的所有子孙。s 也可以看做它自身的一棵子树。
示例 1:
给定的树 s:
3
/
4 5
/
1 2
给定的树 t:
4
/
1 2
返回 true,因为 t 与 s 的一个子树拥有相同的结构和节点值。
示例 2:
给定的树 s:
3
/
4 5
/
1 2
/
0
给定的树 t:
4
/
1 2
返回 false。
bool isSameTree(struct TreeNode* p, struct TreeNode* q) //判断两个数是否相同
{
if (p == NULL && q == NULL)
{
return true;
}
else if (p != NULL && q != NULL)
{
return p->val == q->val&&
isSameTree(p->left, q->left) &&
isSameTree(p->right, q->right);
}
else
{
return false;
}
}
bool isSubtree(struct TreeNode* s, struct TreeNode* t) {
if(s == NULL)
return false;
if(s->val == t->val)
{
if(isSameTree(s,t))
{
return true;
}
}
if(isSubtree(s->left,t))
{
return true;
}
if(isSubtree(s->right,t))
{
return true;
}
return false;
}
本文探讨了如何检查一棵二叉树是否包含另一棵树作为其子树的问题,通过递归算法实现对二叉树结构和节点值的精确匹配。
849

被折叠的 条评论
为什么被折叠?



