7-9 建立与遍历二叉树 分数 25
以字符串的形式定义一棵二叉树的先序序列,若字符是‘#’, 表示该二叉树是空树,否则该字符是相应结点的数据元素。读入相应先序序列,建立二叉链式存储结构的二叉树,然后中序遍历该二叉树并输出结点数据。
输入格式:
字符串形式的先序序列(即结点的数据类型为单个字符)
输出格式:
中序遍历结果
输入样例:
在这里给出一组输入。例如:
ABC##DE#G##F###
输出样例:
在这里给出相应的输出。例如:
CBEGDFA
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
typedef struct node{
char data;
node *l,*r;
}*Bitree;
string s;
int pos;
void build(Bitree &root){ // 建树
if(s[pos]=='#'){
root=NULL;
pos++;
}else{
root=new node;
root->data=s[pos++];
build(root->l); // 建立左子树
build(root->r); // 建立右子树
}
}
void midorder(Bitree root){ // 中序遍历
if(root){
midorder(root->l);
cout<<root->data;
midorder(root->r);
}
}
int main() {
cin>>s;
pos=0;
node *root=new node;
build(root);
midorder(root);
return 0;
}