c语言实现层次遍历二叉树完整代码

//混用了一下c和c++(仅输入输出混用了一下,其他没有)

#include<stdio.h>
#include<stdlib.h>
#include<iostream>
using namespace std;

#define MaxSize 50

//树
typedef char DataType;
typedef struct tnode {
	DataType data;
	struct tnode* lchild, * rchild;
}BT, * BTT;


// 函数声明
BT* Create_(); // 先序创建二叉树
void cen_bianli_(BT* T); //层次遍历二叉树
void visit_(BT* p); //输出函数
void visit2(BT* T); //中序遍历二叉树

//main函数
int main()
{
	BT* T; 

	T = Create_();
	//Create_(T); 
	printf("中序遍历:");
	visit2(T);
	printf("层次遍历:");
	cen_bianli_(T);

	return 0;
}

//中序遍历 
void visit2(BT* T)
{
	//printf("1");
	if (T != NULL)
	{
		visit2(T->lchild);
		printf("%c ", T->data);//cout << T->data << " ";
		visit2(T->rchild);
	}
}


//先序创建二叉树 
BT* Create_()
{
	BT* t;
	char ch;
	cin >> ch;//scanf("%c", &ch);
	getchar();

	if (ch == '#')
	{
		t = NULL;
	}
	else
	{
		t = (BT*)malloc(sizeof(BT));
		t->data = ch;
		printf("请输入%c节点的lchild节点值:", t->data);
		t->lchild = Create_();
		printf("请输入%c节点的rchild节点值:", t->data);
		t->rchild = Create_();
	}
	return t;
}



//纯输出函数 
void visit_(BT* p)
{
	printf("%c,", p->data);//cout << p->data << " " << endl;
}


//层次遍历 
void cen_bianli_(BT* T) //二叉树层次遍历—核心代码
{
	if (!T)
		printf("树空!");
	BTT Q[MaxSize];
	int front, rear;
	front = rear = 0;
	Q[rear++] = T;
	BT* p = NULL;
	while (front < rear)
	{
		p = Q[front++];
		visit_(p);
		if (p->lchild)
			Q[rear++] = p->lchild;
		if (p->rchild)
			Q[rear++] = p->rchild;
	}
}


版权声明:本文为s10087原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。