c语言二叉树代码求解

以先序的方式建立二叉树,并分别以中序、后序的方式遍历该树并输出遍历结果,并使用一些数据验证程序正确性。... 以先序的方式建立二叉树,并分别以中序、后序的方式遍历该树并输出遍历结果,并使用一些数据验证程序正确性。 展开
 我来答
韩和立南婉m
推荐于2016-07-07 · TA获得超过131个赞
知道小有建树答主
回答量:85
采纳率:0%
帮助的人:63.4万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#define MAX 20
#define OK 1
#define ERROR 0
#define NULL 0
#define OVERFLOW 0
typedef char TElemType;
typedef int Status;

typedef struct BiTNode{
TElemType data;
struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;

BiTree CreateBiTree(BiTree T)
{
char ch;
scanf("%c",&ch);
if (ch=='#') T=NULL; /* #代表空指针*/
else
{
T=(BiTNode*)malloc(sizeof(BiTNode));
if(!T) exit(OVERFLOW); /*申请结点 */
T->data=ch; /*生成根结点 */
T->lchild=CreateBiTree(T->lchild); /*构造左子树 */
T->rchild=CreateBiTree(T->rchild); /*构造右子树 */
}
return T;
}

void PreOrder(BiTree T)
{
if (T) {
printf("%c",T->data); // 访问结点
PreOrder(T->lchild); // 遍历左子树
PreOrder(T->rchild);// 遍历右子树
}

}

void InOrder( BiTree T )
{/*中序遍历*/

if (T) {

InOrder(T->lchild); // 遍历左子树
printf("%c",T->data); // 访问结点
InOrder(T->rchild);// 遍历右子树
}

}

void PostOrder( BiTree T )
{/*后序遍历*/
if (T) {
PostOrder(T->lchild); // 遍历左子树
PostOrder(T->rchild);// 遍历右子树
printf("%c",T->data); // 访问结点
}

}

void LevleOrder(BiTree T)
{ /*层次遍历二叉树T,从第一层开始,每层从左到右*/
BiTree Queue[MAX],b;/*用一维数组表示队列,front和rear分别表示队首和队尾指针*/
int front,rear;
front=rear=0;
if(T) /*若树非空*/
{
Queue[rear++]=T; /*根结点入队列*/
while (front!=rear)
{ /*当队列非空*/
b=Queue[front++]; /*队首元素出队列,并访问这个结点*/
printf("%2c",b->data);
if(b->lchild!=NULL) Queue[rear++]=b->lchild; /*左子树非空,则入队列*/
if(b->rchild!=NULL) Queue[rear++]=b->rchild; /*右子树非空,则入队列*/
}
}
}/*LevelOrder*/
void main()
{
BiTree B,T;
//BiTNode T;
printf("\n请读入构造二叉树的字符序列:");
B=CreateBiTree(T); /*建立一棵二叉树T*/
//B=&T;
printf("\n该二叉树的先序遍历是:");
PreOrder(B); /*先序遍历二叉树*/
printf("\n该二叉树的中序遍历");
InOrder( B); /*中序遍历二叉树*/
printf("\n该二叉树的后序遍历");
PostOrder( B); /*后序遍历二叉树*/
printf("\n该二叉树的层次遍历是:");
LevleOrder(B); /*层次遍历二叉树*/

}
blackpanda1126
2014-10-29 · TA获得超过485个赞
知道小有建树答主
回答量:489
采纳率:25%
帮助的人:309万
展开全部
你这也太无语了,5分都不舍得给
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式