数据结构上机测试4.1:二叉树的遍历与应用1

来源:互联网 发布:java 解析器模式 编辑:程序博客网 时间:2024/05/16 08:04

数据结构上机测试4.1:二叉树的遍历与应用1

Time Limit: 1000MS Memory limit: 65536K

题目描述

输入二叉树的先序遍历序列和中序遍历序列,输出该二叉树的后序遍历序列。

输入

第一行输入二叉树的先序遍历序列;
第二行输入二叉树的中序遍历序列。

输出

输出该二叉树的后序遍历序列。

示例输入

ABDCEFBDAECF

示例输出

DBEFCA
  1. #include<stdio.h>  
  2. #include<string.h>  
  3. #include<malloc.h>   
  4. typedef struct tnode  
  5. {  
  6.      char data;    
  7.      tnode *left, *right;    
  8. }TNODE2;  
  9. TNODE2 *make(char *pstr,char *istr,int n)  
  10.        
  11. {  
  12.     TNODE2 *ptr;  
  13.     char *rstr;  
  14.     int k;  
  15.     if(n<=0) return NULL;  
  16.     ptr = (TNODE2*)malloc(sizeof(TNODE2));  
  17.     ptr->data = *pstr;     
  18.     for(rstr=istr;rstr<istr+n;rstr++)  
  19.         if(*rstr == *pstr)  
  20.             break; 
  21.     k = rstr - istr; 
  22.     ptr->left = make(pstr+1,istr,k);  
  23.     ptr->right = make(pstr+k+1,istr+k+1,n-k-1);  
  24.     return ptr;  
  25. }  
  26. void lastorder(TNODE2 *t)  
  27.   
  28. {  
  29.     if(t == NULL) return ;  
  30.     lastorder(t->left);  
  31.     lastorder(t->right);  
  32.     printf("%c",t->data);  
  33. }  
  34. int main()  
  35. {  
  36.     TNODE2 *tree;  
  37.     char a[100],b[100];  
  38.     scanf("%s",a);  
  39.     scanf("%s",b);  
  40.     //char *a = "abdegcf";  
  41.     //char *b = "dbeacgf";  
  42.     int n = strlen(a);  
  43.     tree = make(a,b,n);  
  44.     lastorder(tree);  
  45.     printf("\n");  
  46.     return 0;  
  47. }  
  48.   
0 0