数据结构_二叉树的高度与层次遍历
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
#include
#include
typedef struct BTNode
{
char data;
struct BTNode * lchild;
struct BTNode * rchild;
}BTNode;
void CreateBTree(BTNode *&T)//二叉树的先序建立
{
char ch;
scanf("%c",&ch);
if(ch=='#')
{
T=NULL;
return;
}
else
{
T=(BTNode *)malloc(sizeof(BTNode));
T->data=ch;
CreateBTree(T->lchild);
CreateBTree(T->rchild);
}
}
void PreOrder(BTNode *T)//先序遍历
{
if(NULL != T)
{
printf("%c\t",T->data);
PreOrder(T->lchild);
PreOrder(T->rchild);
}
}
void InOrder(BTNode *T)//中序遍历
{
if(NULL != T)
{
InOrder(T->lchild);
printf("%c\t",T->data);
InOrder(T->rchild);
}
}
void PostOrder(BTNode *T)//后续遍历
{
if(NULL != T)
{
PostOrder(T->lchild);
PostOrder(T->rchild);
printf("%c\t",T->data);
}
}
int Height(BTNode *T)
{
int L,R;
if(NULL == T)
return 0;
else
{
L=Height(T->lchild);
R=Height(T->rchild);
return L>R ? L+1 :R+1;
}
}
const int MAXSIZE=100;
BTNode * Q[MAXSIZE];
int front=0;
int rear=0;
void VisitByLayer(BTNode *T)
{
BTNode *s=NULL;
if(NULL != T)
{
Q[rear] = T;
rear=(rear+1)%MAXSIZE;
while(front != rear)
{
s=Q[front];
front=(front+1)%MAXSIZE;
printf("%c\t",s->data);
if(NULL != s->lchild)
{
Q[rear]=s->lchild;
rear=(rear+1)%MAXSIZE;
}
if(NULL != s->rchild)
{
Q[rear]=s->rchild;
rear=(rear+1)%MAXSIZE;
}
}
}
}
int main(void)
{
BTNode *T;
CreateBTree(T);
printf("线序遍历序列如下:");
PreOrder(T);
printf("层次遍历序列如下:");
VisitByLayer(T);
putchar(10);
printf("\n二叉树高度为:%d\n",Height(T));
putchar(10);
system("pause");
return 0;
}