【C语言】 二叉树创建(结构体,先序遍历,中序遍历,后续遍历)

         二叉树的创建:首先先定义一个结构体,里面包含数据(data),指向左子树的指针(L),指向右子树的指针(R)三个部分
        在创建树的函数中,首先先输入一个数,且当输入'#'的时候,表示这个位置没有值输入,返回NULL;成功输入值后,用malloc申请一个结点,B->data = data;然后再次调用创建函数(函数本身),但是是这个结点的左子树B->L = tree_create();以此类推就能成功创建一颗树了。
        3种遍历方法结构基本差不多,无非是输出的时机不一样,先序是根左右,中序是左根右,后序是左右根。遍历即可输出值

//bitree.h
#ifndef BITREE_H
#define BITREE_H

#include<myhead.h>

typedef char datatype;

typedef struct Node
{
	datatype data;
	struct Node *L;
	struct Node *R;
}Node,*BiTreePtr;

//创建树
BiTreePtr tree_create();


//先序遍历树
void prio_order(BiTreePtr B);


//中序遍历树
void in_order(BiTreePtr B);


//后序遍历树
void post_order(BiTreePtr B);


#endif
//bitree.c
#include"bitree.h"

//创建树
BiTreePtr tree_create()
{
	//输入一个数
	char data = '0';
	scanf("%c",&data);
	getchar();

	//如果输入#代表这个位置没有数放入,返回NULL
	if(data == '#')
	{
		return NULL;
	}

	//申请树的空间,如果不是NULL,就要申请结点
	BiTreePtr B = (BiTreePtr)malloc(sizeof(Node));
	if(NULL == B)     //判断是否成功创建
	{
		printf("创建失败");
		return NULL;
	}

	//执行到这里说明树申请成功
	B->data = data;    //赋值给节点

	B->L = tree_create(); //创建左子树
	B->R = tree_create(); //创建右子树

	return B;
}


//先序遍历树
void prio_order(BiTreePtr B)
{
	//判断逻辑
	if(NULL == B)
	{
		return;     //递归出口
	}

	printf("%c\t",B->data);  //先打印出根节点
	
	prio_order(B->L);     //遍历左子树
	
	prio_order(B->R);     //遍历右子树
}


//中序遍历树
void in_order(BiTreePtr B)
{
	//判断逻辑
	if(NULL == B)
	{
		return;     //递归出口
	}
	in_order(B->L);     //遍历左子树
	
	printf("%c\t",B->data);  //先打印出根节点
	
	in_order(B->R);     //遍历右子树

}

//后序遍历树
void post_order(BiTreePtr B)
{
	//判断逻辑
	if(NULL == B)
	{
		return;     //递归出口
	}
	post_order(B->L);     //遍历左子树
	
	post_order(B->R);     //遍历右子树

	printf("%c\t",B->data);  //先打印出根节点

}
//main.c
#include"bitree.h"

#include <myhead.h>

int main(int argc, 	const char *argv[])
{
	BiTreePtr B = tree_create();
	if(NULL == B)
	{
		printf("创建失败\n");
		return -1;
	}
	else
	{
		printf("创建成功\n");
	}
	printf("先序遍历为:");
	prio_order(B);
	printf("\n");
	
	printf("中序遍历为:");
	in_order(B);
	printf("\n");
	
	printf("后序遍历为:");
	post_order(B);
	printf("\n");
	return 0;
}

创建了这样一个树

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值