题目:输入两颗二叉树A和B,判断B是不是A的子结构。二叉树节点的定义如下:
struct BinaryTreeNode
{
double m_dbValue;
BinaryTreeNode* m_pLeft;
BinaryTreeNode* m_pRight;
};
- 在树A中找到和树B的根节点的值一样的节点R
- 判断树A中以R为根节点的子树是不是包含和树B一样的结构
bool HasSubtree(BinaryTreeNode* pRoot1,BinaryTreeNode* pRoot2)
{
bool result=false;
if(pRoot1!=nullptr&&pRoot2!=nullptr)
{
if(Equal(pRoot1->m_dbValue,pRoot2->m_dbValue))
result=DoesTree1HaveTree2(pRoot1,pRoot2);
if(!result)
result=HasSubtree(pRoot1->m_pLeft,pRoot2);
if(!result)
result=HasSubtree(pRoot1->m_pRight,pRoot2);
}
return result;
}
bool DoesTree1HaveTree2(BinaryTreeNode* pRoot1,BinaryTreeNode* pRoot2)
{
if(pRoot2==nullptr)
return true;
if(pRoot1==nullptr)
return false;
if(!Equal(pRoot1->m_dbValue,pRoot2->m_dbValue))
return false;
return DoseTree1HaveTree2(pRoot1->m_pLeft,pRoot2->m_pLeft)&&DoseTree1HaveTree2(pRoot1->m_pRight,pRoot2->m_pRight);
}
本题中节点中值的类型为double。在判断两个节点的值是不是相等时,不能直接写==判断,这是因为在计算机内表示小数时都有误差。判断两个小数是否相等,只能判断它们之差的绝对值是不是在一个很小的范围内。如果两个数相差很小,就可以认为它们相等。
bool Equal(double num1,double num2)
{
if((num1-num2>-0.0000001)&&(num1-num2<0.0000001))
return true;
else
return false;
}