本题要求根据给定的一棵二叉树的后序遍历和中序遍历结果,输出该树的先序遍历结果。
输入格式:
第一行给出正整数N(≤),是树中结点的个数。随后两行,每行给出N个整数,分别对应后序遍历和中序遍历结果,数字间以空格分隔。题目保证输入正确对应一棵二叉树。
输出格式:
在一行中输出Preorder:
以及该树的先序遍历结果。数字间有1个空格,行末不得有多余空格。
输入样例:
7
2 3 1 5 7 6 4
1 2 3 4 5 6 7
输出样例:
Preorder: 4 1 3 2 6 5 7
#include<iostream> #include<malloc.h> using namespace std; #define maxn 35 typedef struct BiNode{ int data; struct BiNode *lchild,*rchild; }BiNode,*BiTree; BiTree Create(int *str1,int *str2,int n) { BiTree T=(BiTree)malloc(sizeof(BiNode)); if(n<=0) T=NULL; else{ int i; T->data=str1[n-1]; for(i=0;str2[i]!=str1[n-1];i++); T->lchild=Create(str1,str2,i); T->rchild=Create(str1+i,str2+1+i,n-i-1); } return T; } void PreOrder(BiTree T) { if(T) { cout<<" "<<T->data; PreOrder(T->lchild); PreOrder(T->rchild); } } int main() { BiTree T; int n,str1[maxn],str2[maxn]; cin>>n; for(int i=0;i<n;i++) cin>>str1[i]; for(int i=0;i<n;i++) cin>>str2[i]; T=Create(str1,str2,n); cout<<"Preorder:"; PreOrder(T); return 0; }