6-7 二叉树的遍历
本题要求给定二叉树的4种遍历。
函数接口定义:
void InorderTraversal( BinTree BT );
void PreorderTraversal( BinTree BT );
void PostorderTraversal( BinTree BT );
void LevelorderTraversal( BinTree BT );
其中BinTree
结构定义如下:
typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{
ElementType Data;
BinTree Left;
BinTree Right;
};
要求4个函数分别按照访问顺序打印出结点的内容,格式为一个空格跟着一个字符。
裁判测试程序样例:
#include <stdio.h>
#include <stdlib.h>
typedef char ElementType;
typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{
ElementType Data;
BinTree Left;
BinTree Right;
};
BinTree CreatBinTree(); /* 实现细节忽略 */
void InorderTraversal( BinTree BT );
void PreorderTraversal( BinTree BT );
void PostorderTraversal( BinTree BT );
void LevelorderTraversal( BinTree BT );
int main()
{
BinTree BT = CreatBinTree();
printf("Inorder:"); InorderTraversal(BT); printf("\n");
printf("Preorder:"); PreorderTraversal(BT); printf("\n");
printf("Postorder:"); PostorderTraversal(BT); printf("\n");
printf("Levelorder:"); LevelorderTraversal(BT); printf("\n");
return 0;
}
/* 你的代码将被嵌在这里 */
输出样例(对于图中给出的树):
Inorder: D B E F A G H C I
Preorder: A B D F E C G H I
Postorder: D E F B H G I C A
Levelorder: A B C D F G I E H
代码如下:
void InorderTraversal( BinTree BT )//中序遍历
{
if(BT!= NULL){
InorderTraversal(BT->Left); //递归遍历左子树
printf(" %c",BT->Data); //输出根节点的Data
InorderTraversal(BT->Right); //递归遍历右子树
}
}
void PreorderTraversal( BinTree BT )//先序遍历
{
if(BT!= NULL){
printf(" %c",BT->Data); //输出根结点的Data
PreorderTraversal(BT->Left); //递归遍历左子树
PreorderTraversal(BT->Right); //递归遍历右子树
}
}
void PostorderTraversal( BinTree BT )//后序遍历
{
if(BT!= NULL){
PostorderTraversal(BT->Left); //递归遍历左子树
PostorderTraversal(BT->Right); //递归遍历右子树
printf(" %c",BT->Data); //输出根结点的Data
}
}
void LevelorderTraversal( BinTree BT )//层次遍历
{
BinTree data[50];//
int rear,front;
char x;
rear=front=0; //InitQueue(Q);初始化辅助队列
BinTree p;
p=(BinTree)malloc(sizeof(struct TNode *));
if(BT==NULL) return ;
//EnQueue(Q,BT);将根结点入队
data[rear]=BT;
rear=(rear+1)%50;
while(rear!=front) //!IsEmpty(Q)队列不空循环
{
//DeQueue(Q,p); 队头元素出队
p=data[front];
front=(front+1)%50;
printf(" %c",p->Data); //visit(p);访问当前p所指向的结点
if(p->Left!=NULL) //EnQueue(Q,p->Left); 左子树不空,则左子树入队列
{
data[rear]=p->Left;
rear=(rear+1)%50;
}
if(p->Right!=NULL) //EnQueue(Q,p->Right); 右子树不空,则右子树入队列
{
data[rear]=p->Right;
rear=(rear+1)%50;
}
}
}