题目要求:输入两棵二叉树A和B,判断B是不是A的子结构,二叉树结点定义如下:
此题目的总结:主要使用链表的遍历和递归
struct BinaryTreeNode
{
int m_nValue;
BinaryTreeNode m_pLeft;
BinaryTreeNode m_pRight;
};
以上经典的二叉树定义;
以下为主体函数部分
bool HasSubTree(BinaryTreeNode* pRoot1,BinaryTreeNode* pRoot2)
{
bool result; //bool函数常做为判定来用,很好的利用bool类型十分关键
if(pRoot1!==NULL&&pRoot2!==NULL) //保证输入二叉树不为空,保证程序的鲁棒性
{
if(pRoot1-> m_nValue== pRoot2-> m_nValue)
result=DoesTree1HaveTree2(pRoot1,pRoot2);
if(!result)//在二叉树第一个结点不和将要比较那个二叉树第一个结点相等时比较它的左子树
result=HasSubTree(pRoot1->m_pLeft,pRoot2);
if(!result)//在搜寻完主二叉树的左子树没找到以后,再搜寻右子树
result=HasSubTree(pRoot1->m_pRight,pRoot2);
}
return result;//返回result做为判断;
}
bool DoesTree1HaveTree2(BinaryTreeNode* pRoot1,BinaryTreeNode* pRoot2)
{
if(pRoot2==NULL)//如果将要比较的二叉树为空时不需要比较自动返回真
return true;
if(pRoot1==NULL)//如果主二叉树没有找到与将要比较的二叉树相同部分返回false
return false;
if(pRoot1->m_nValue!=pRoot2->m_nValue)如果两个结点不等
return false;
return DoesTree1HaveTree2(pRoot1->m_pLeft,pRoot12->m_pLeft)&& DoesTree1HaveTree2(pRoot1->m_pRight,pRoot12->m_pRight);//递归比较后面的结点
}