您的位置:首页 > 其它

比较两棵可旋转二叉树是否相等

2015-10-08 13:07 211 查看
  二叉树左右子结点可旋转是指:可以把二叉树的左结点旋转成为右子树,把右子树的结点旋转成为左子树。这个与判断两棵二叉树的逻辑相同,只是要交叉判断。

算法思路:在文章http://www.cnblogs.com/houjun/p/4860680.html的基础上,把判断代码改成如下:

if(T1->data == T2->data) //如果根节点相等
return (isEqual(T1->lc,T2->lc) && isEqual(T1->rc,T2->rc))
||(isEqual(T1->lc,T2->rc) && isEqual(T1->rc,T2->lc));


完整算法为:

//二叉树节点结构体
struct BinaryNode
{
int data;
BinaryNode * lc;
BinaryNode * rc;
}*BTree;

//判断二叉树是否相等的函数

bool isEqual(BTree T1,BTree T2)
{
if(T1 == NULL && T2 == NULL)
return true;//都为空,相等。
if(!T1||!T2)    //由于上面的判断不成立,则T1,T2至少有一个不为空
return false;//一个空,一个不空,不相等
if(T1->data == T2->data) //如果根节点相等
return (isEqual(T1->lc,T2->lc) && isEqual(T1->rc,T2->rc))//判断左右子树是否都相等
||(isEqual(T1->lc,T2->rc) && isEqual(T1->rc,T2->lc));
else
return false;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: