一,树的子结构
题目描述
输入两棵二叉树A与B,判断B是不是A的子结构。
我的代码
bool BackTrack(BSTNode *p1, BSTNode *p2){
if(p1 == NULL && p2 == NULL){
return true;
}
if(p1 == NULL || p2 == NULL){
return false;
}
if(p1->data == p2->data){
return BackTrack(p1->lchild, p2->lchild) && BackTrack(p1->rchild, p2->rchild);
} else {
return false;
}
}
bool hasSubTree(BSTNode *p1, BSTNode *p2){
bool result = false;
result = BackTrack(p1, p2);
if(!result){
result = BackTrack(p1->lchild, p2);
}
if(!result){
result = BackTrack(p1->rchild, p2);
}
return result;
}
本文介绍了一种算法,用于判断一棵二叉树是否为另一棵二叉树的子结构。通过递归的方式,对比两个二叉树节点的值是否相同,并进一步检查左子树和右子树。
474

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



