烟台大学计算机与控制工程学院数据结构课程实验报告
BTNode *s;
char *p;
int k;
if (n<=0) return NULL;
s=(BTNode *)malloc(sizeof(BTNode)); //创建二叉树节点 s
s->data=*pre;
for (p=in;p<in+n;p++) //在中序序列中找等于*ppos 的位置 k
if (*p==*pre) //pre 指向根节点
break; //在 in 中找到后退出循环
k=p-in; //确定根节点在 in 中的位置
s->lchild=CreateBT1(pre+1,in,k); //递归构造左子树
s->rchild=CreateBT1(pre+k+1,p+1,n-k-1); //递归构造右子树
return s;
}
BTNode *CreateBT2(char *post,char *in,int n)
/*post 存放后序序列,in 存放中序序列,n 为二叉树节点个数,
本算法执行后返回构造的二叉链的根节点指针*/
{
BTNode *s;
char r,*p;
int k;
if (n<=0) return NULL;
r=*(post+n-1); //根节点值
s=(BTNode *)malloc(sizeof(BTNode)); //创建二叉树节点 s
s->data=r;
for (p=in;p<in+n;p++) //在 in 中查找根节点
if (*p==r)
break;
k=p-in; //k 为根节点在 in 中的下标
s->lchild=CreateBT2(post,in,k); //递归构造左子树
s->rchild=CreateBT2(post+k,p+1,n-k-1); //递归构造右子树
return s;
}
int main()
{
ElemType pre[]="ABDGCEF",in[]="DGBAECF",post[]="GDBEFCA";
BTNode *b1,*b2;
评论0
最新资源