码迷,mamicode.com
首页 > 编程语言 > 详细

【算法】二叉树的递归遍历C语言实现

时间:2015-02-07 18:56:16      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:二叉树   c语言   数据结构   算法   遍历   

二叉树是一种极其重要的数据结构,以下是二叉树的结构定义 创建 和递归先序 中序 后序 遍历的代码.



#include<stdio.h>
#include<stdlib.h>

typedef char ElemType;

/*二叉树节点数据结构*/
typedef struct node{
	ElemType data;
	struct treenode *lChild;
	struct treenode *rChild;
} TreeNode;

/*使用先序遍历创建二叉树*/
TreeNode *createBiTreeInPreOrder(){
	ElemType ch;
	TreeNode *T;
	
	scanf("%ch", &ch);	//这样调用scanf函数时,树的节点一次全部输入,如果要一次输入一个的话,那么在格式化字符串%ch前面加上空格即可
	if(ch != '#'){
		T = (TreeNode *)malloc(sizeof(TreeNode));
		if(T == NULL){
			printf("内存空间不足,程序退出\n");
			exit(-1);
		}
		T->data = ch;
		T->lChild = createBiTreeInPreOrder();
		T->rChild = createBiTreeInPreOrder();
	} else{
		T = NULL;
	}

	return T;
}

/*使用中序遍历创建二叉树*/
TreeNode *createBiTreeInInOrder(){
	ElemType ch;
	TreeNode *T;
	
	scanf("%ch", &ch);	//这样调用scanf函数时,树的节点一次全部输入,如果要一次输入一个的话,那么在格式化字符串%ch前面加上空格即可
	if(ch != '#'){
		T = (TreeNode *)malloc(sizeof(TreeNode));
		if(T == NULL){
			printf("内存空间不足,程序退出\n");
			exit(-1);
		}
		T->lChild = createBiTreeInInOrder();
		T->data = ch;
		T->rChild = createBiTreeInInOrder();
	} else{
		T = NULL;
	}

	return T;
}

/*使用后序遍历创建二叉树*/
TreeNode *createBiTreeInPostOrder(){
	ElemType ch;
	TreeNode *T;
	
	scanf("%ch", &ch);	//这样调用scanf函数时,树的节点一次全部输入,如果要一次输入一个的话,那么在格式化字符串%ch前面加上空格即可
	if(ch != '#'){
		T = (TreeNode *)malloc(sizeof(TreeNode));
		if(T == NULL){
			printf("内存空间不足,程序退出\n");
			exit(-1);
		}
		T->lChild = createBiTreeInPostOrder();
		T->rChild = createBiTreeInPostOrder();
		T->data = ch;
	} else{
		T = NULL;
	}

	return T;
}

/*先序遍历*/
void PreOrderTraverse(TreeNode *T)
{
    ElemType data;
    if(T!=NULL)
    {
        data=T->data;
        printf("%c ",data);
        PreOrderTraverse(T->lChild);
        PreOrderTraverse(T->rChild);
    }
}

/*中序遍历*/
void InOrderTraverse(TreeNode *T)
{
    ElemType data;
    if(T!=NULL)
    {
        data=T->data;
        InOrderTraverse(T->lChild);
		printf("%c ",data);
        InOrderTraverse(T->rChild);
    }
}

/*先序遍历*/
void PostOrderTraverse(TreeNode *T)
{
    ElemType data;
    if(T!=NULL)
    {
        data=T->data;
        PostOrderTraverse(T->lChild);
        PostOrderTraverse(T->rChild);
		printf("%c ",data);
    }
}



int main(void){
	char ch;

	TreeNode *tree;
	tree = createBiTreeInPreOrder();

	PreOrderTraverse(tree);

	scanf("%c", &ch);
	scanf("%c", &ch);
	return 0;
}


【算法】二叉树的递归遍历C语言实现

标签:二叉树   c语言   数据结构   算法   遍历   

原文地址:http://blog.csdn.net/lchad/article/details/43605239

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!