码迷,mamicode.com
首页 > 其他好文 > 详细

由先序遍历序列和中序遍历序列确定二叉树

时间:2019-12-16 13:35:52      阅读:94      评论:0      收藏:0      [点我收藏+]

标签:lib   span   class   后序   style   pos   ++   malloc   null   

如何通过先序遍历序列和中序遍历序列来确定一棵二叉树?

  • 根据先序遍历序列第一个结点确定根结点;
  • 根据根结点在中序遍历序列中分割出左右两个子序列;
  • 对左子树和右子树分别递归使用相同的方式继续分解;
  1 #include <stdio.h>
  2 #include <stdlib.h>
  3 #include <string.h>
  4  
  5 struct node
  6 {
  7     char data;
  8     struct node *lt, *rt;
  9 };
 10 
 11 // 用先序序列和中序序列建立二叉树
 12 struct node *create_by_pre_and_mid(int n, char *pre, char *mid)
 13 {
 14     struct node *root;
 15     int i;
 16 
 17     if(n==0)
 18         return NULL;
 19 
 20     root=(struct node *)malloc(sizeof(struct node));
 21     root->data=pre[0];
 22 
 23     for(i=0;i<n;i++)///寻找左右子树的元素
 24         if(pre[0]==mid[i])
 25             break;
 26 
 27     root->lt = create_by_pre_and_mid(i, pre+1, mid); // 建立左子树
 28     root->rt = create_by_pre_and_mid(n-i-1, pre+i+1, mid+i+1); // 建立右子树
 29 
 30     return root;
 31 }
 32 
 33 // 用后序序列和中序序列建立二叉树
 34 struct node *create_by_post_and_mid(int n, char *post, char *mid)
 35 {
 36     struct node *root;
 37     int i;
 38 
 39     if(n==0)
 40         return NULL;
 41 
 42     root=(struct node *)malloc(sizeof(struct node));
 43     root->data=post[n-1];
 44 
 45     for(i=0;i<n;i++) // 寻找左右子树的元素
 46         if(post[n-1]==mid[i])
 47             break;
 48 
 49     root->lt = create_by_post_and_mid(i, post, mid); // 建立左子树
 50     root->rt = create_by_post_and_mid(n-i-1, post+i, mid+i+1); // 建立右子树
 51 
 52     return root;
 53 }
 54  
 55 // 后序遍历
 56 void postorder(struct node *root)
 57 {
 58     if(root)
 59     {
 60         postorder(root->lt);
 61         postorder(root->rt);
 62         printf("%c", root->data);
 63     }
 64 }
 65 
 66 // 前序遍历
 67 void preorder(struct node *root)
 68 {
 69     if(root)
 70     {
 71         printf("%c", root->data);       
 72         preorder(root->lt);
 73         preorder(root->rt);
 74     }
 75 }
 76 
 77 // 中序遍历
 78 void midorder(struct node *root)
 79 {
 80     if(root)
 81     {
 82         midorder(root->lt);
 83         printf("%c", root->data);          
 84         midorder(root->rt);
 85     }
 86 }
 87 
 88 
 89 int main( void )
 90 {
 91     struct node *root=NULL;
 92     int len;
 93     char *post = "DFEBGIHCA";
 94     char *pre = "ABDEFCGHI";
 95     char *mid = "DBFEAGCHI";
 96 
 97     len=strlen(post);
 98 
 99     //root=create_by_pre_and_mid(len, pre, mid);
100     root = create_by_post_and_mid(len, post, mid);
101 
102     printf("\r\npreorder:\r\n");
103     preorder(root);
104 
105     printf("\r\nmidorder:\r\n");
106     midorder(root);
107 
108     printf("\r\npostorder:\r\n");
109     postorder(root);
110 
111     printf("\r\n");
112 
113 
114     system("pause");
115     return 0;
116 }

 

由先序遍历序列和中序遍历序列确定二叉树

标签:lib   span   class   后序   style   pos   ++   malloc   null   

原文地址:https://www.cnblogs.com/utank/p/12048322.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!