输出利用先序遍历创建的二叉树的层次遍历序列
1000(ms)
10000(kb)
2817 / 6152
利用先序递归遍历算法创建二叉树并输出该二叉树的层次遍历序列。先序递归遍历建立二叉树的方法为:按照先序递归遍历的思想将对二叉树结点的抽象访问具体化为根据接收的数据决定是否产生该结点从而实现创建该二叉树的二叉链表存储结构。约定二叉树结点数据为单个大写英文字符。当接收的数据是字符"#"时表示该结点不需要创建,否则创建该结点。最后再输出创建完成的二叉树的层次遍历序列。需要注意输入数据序列中的"#"字符和非"#"字符的序列及个数关系,这会最终决定创建的二叉树的形态。
输入
输入为接受键盘输入的由大写英文字符和"#"字符构成的一个字符串(用于创建对应的二叉树)。
输出
每个用例用一行出该用例对应的二叉树的层次遍历序列。
样例输入
A## ABC#### AB##C## ABCD###EF##G##H## A##B##
样例输出
A ABC ABC ABHCEDFG A
#include<stdio.h>
#include<malloc.h>
struct BTNode
{
char data;
struct BTNode *lchild;//左孩子结点
struct BTNode *rchild;//右孩子结点
};
struct SqQueue
{
struct BTNode *data[100];//储存二叉树结点的数组队列
int front,rear;//前标记和后标记
};
void PreOrder(struct BTNode *&p)//先序遍历创建二叉树
{
char a;
scanf("%c",&a);
if(a=='#') p=NULL;
else
{
p=(struct BTNode *)malloc(sizeof(struct BTNode));
p->data=a;
PreOrder(p->lchild);
PreOrder(p->rchild);
}
}
void LevelOrder(struct BTNode *p)
{
struct SqQueue *t;
t=(struct SqQueue *)malloc(sizeof(struct SqQueue));
t->front=t->rear=-1;//初始化前后标记位置
t->data[++t->rear]=p;//将头结点入队
while(t->front!=t->rear)
{
printf("%c",t->data[++t->front]->data);//输出当前 前标记位置的二叉树
p=t->data[t->front];//取出当前 前标记的二叉树
if(p->lchild!=NULL) t->data[++t->rear]=p->lchild;//如果左孩子不为空,则入队
if(p->rchild!=NULL) t->data[++t->rear]=p->rchild;//如果右孩子不为空,则入队
}
}
int main()
{
struct BTNode *head;
PreOrder(head);
LevelOrder(head);
}