数据结构第十周项目——验证算法(二)

来源:互联网 发布:java jelly 编辑:程序博客网 时间:2024/06/11 18:57
  1. /*     
  2. *Copyright (c) 2017,烟台大学计算机与控制工程学院     
  3. *All rights reserved.     
  4. *文件名称:项目1-验证算法(2)    
  5. *作    者:董丽娟     
  6. *完成日期:2017年11月2日     
  7. *版 本 号:v1.0     
  8. * 问题:     
  9. 二叉树构造算法的验证 
  10. 代码:  

  1. */      
  1. #include <stdio.h>  
  2. #include <malloc.h>  
  3. #include "btree.h"  
  4.   
  5. BTNode *CreateBT1(char *pre,char *in,int n)  
  6. /*pre存放先序序列,in存放中序序列,n为二叉树结点个数, 
  7. 本算法执行后返回构造的二叉链的根结点指针*/  
  8. {  
  9.     BTNode *s;  
  10.     char *p;  
  11.     int k;  
  12.     if (n<=0) return NULL;  
  13.     s=(BTNode *)malloc(sizeof(BTNode));     //创建二叉树结点*s  
  14.     s->data=*pre;  
  15.     for (p=in; p<in+n; p++)                 //在中序序列中找等于*ppos的位置k  
  16.         if (*p==*pre)                       //pre指向根结点  
  17.             break;                          //在in中找到后退出循环  
  18.     k=p-in;                                 //确定根结点在in中的位置  
  19.     s->lchild=CreateBT1(pre+1,in,k);        //递归构造左子树  
  20.     s->rchild=CreateBT1(pre+k+1,p+1,n-k-1); //递归构造右子树  
  21.     return s;  
  22. }  
  23.   
  24. int main()  
  25. {  
  26.     ElemType pre[]="ABDGCEF",in[]="DGBAECF";  
  27.     BTNode *b1;  
  28.     b1=CreateBT1(pre,in,7);  
  29.     printf("b1:");  
  30.     DispBTNode(b1);  
  31.     printf("\n");  
  32.     return 0;  
  33. }  

原创粉丝点击