二叉树是一种极其重要的数据结构,以下是二叉树的结构定义 创建 和递归先序 中序 后序 遍历的代码.
#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;
}