已知层次遍历和中序遍历求二叉树_C语言根据层次遍历和中序遍历求二叉树的前序遍历和后序遍历。下面有我的建树函数,有注释的。...

本文介绍如何使用C语言根据层次遍历和中序遍历序列构建二叉树。提供了一个名为`BuildTree`的函数,通过递归方式完成建树过程。通过层次遍历和中序遍历的字符串,该函数可以生成对应的二叉树,并输出前序和后序遍历的结果。
摘要由CSDN通过智能技术生成

voidBuildTree(char*level,char*inorder,pBiTreeT){inti;intlen=strlen(level);//取得层次遍历长度intpos;if(len==0)return;char*p=strchr(inorder,level[0]);if(p==NULL)//如果为空则...

void BuildTree(char *level,char *inorder,pBiTree T)

{

int i;

int len=strlen(level); //取得层次遍历长度

int pos;

if(len==0)

return ;

char *p=strchr(inorder,level[0]);

if(p==NULL) //如果为空则抛弃第一个,跳到下一个;

{

char *L=(char*)malloc(sizeof(char)*len); //开辟数组

strncpy(L,level+1,len-1); //舍弃第一个

L[len-1]=0;

T->lchild=NULL;

T->rchild=NULL;

BuildTree(L,inorder,T); //调用建树函数

return ;

}else{

pos=p-inorder; //得到中序遍历左子树字符串长度

T->data=level[0]; //为根节点赋值

T->lchild=NULL;

T->rchild=NULL;

}

if(pos!=0) //左子树的递归调用

{

pBiTree left;

T->lchild=(pBiTree)malloc(sizeof(BiNode));

left=T->lchild;

char *left_level=(char*)malloc(sizeof(char)*len);

char *left_inor=(char*)malloc(sizeof(char)*(pos));

strncpy(left_level,level+1,len-1); //舍去层次遍历第一个

strncpy(left_inor,inorder,pos); //截取左子树字符串

left_level[len-1]=0;

left_inor[pos]=0;

BuildTree(left_level,left_inor,left);

}

if(pos!=len-1) //右子树的递归调用

{

pBiTree right;

T->rchild=(pBiTree)malloc(sizeof(BiNode));

right=T->rchild;

char *right_level=(char*)malloc(sizeof(char)*(len));

char *right_inor=(char*)malloc(sizeof(char)*(len-pos));

strncpy(right_level,level+1,len-1);

strncpy(right_inor,inorder+pos+1,len-pos-1);

right_level[len-1]=0;

right_inor[len-pos-1]=0;

BuildTree(right_level,right_inor,right);

}

}

运行结果:

2

输入:

CBA

BCA

输出:

CB燗

燘AC

输入:

BACDE

DAEBC

输出:

BAD燛C

燚EA谻B

展开

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值