推荐《数据结构》(c语言版)(清华大学出版社,严蔚敏,吴伟民编著)教材。
《清华大学计算机系列教材:数据结构(C语言版)》的第1章综述数据、数据结构和抽象数据类型等基本概念;第2章至第7章从抽象数据类型的角度,分别讨论线性表、栈、队列、串、数组、广义表、树和二叉树以及图等基本类型的数据结构及其应用。
第8章综合介绍操作系统和编译程序中涉及的动态存储管理的基本技术。
第9章至第11章讨论查找和排序,除了介绍各种实现方法之外,并着重从时间上进行定性或定量的分析和比较;第12章介绍常用的文件结构。
本书可作为计算机类专业或信息类相关专业的本科或专科教材。
数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率。数据结构往往同高效的检索算法和索引技术有关。
// 二叉树的先序遍历序列: A B C E D F H G I J// 二叉树的中序遍历序列: E C B H F D J I G A
// 二叉树的后序遍历序列: E C H F J I G D B A
#include "stdio.h"
#include "stdlib.h"
struct tree
{
char data
struct tree *left
struct tree *right
}
typedef struct tree treenode
typedef treenode *btree
btree createbtree(char *data,int pos,int maxPos) //递归创建法
{
btree newnode
if(data[pos]==0 || pos>maxPos)
{
return NULL
}
else
{
newnode=(btree)malloc(sizeof(treenode))
newnode->data=data[pos]
newnode->left=createbtree(data,2*pos,maxPos)
newnode->right=createbtree(data,2*pos+1,maxPos)
return newnode
}
}
void inorder(btree ptr)
{
if(ptr!=NULL)
{
inorder(ptr->left)
printf("%C ",ptr->data)
inorder(ptr->right)
}
}
void preorder(btree ptr)
{
if(ptr!=NULL)
{
printf("%C ",ptr->data)
preorder(ptr->left)
preorder(ptr->right)
}
}
void postorder(btree ptr)
{
if(ptr!=NULL)
{
postorder(ptr->left)
postorder(ptr->right)
printf("%C ",ptr->data)
}
}
int main()
{
btree root=NULL
int i
char data[64]={0,'A','B',0,'C','D',0,0,
'E',0,'F','G',0,0,0,0,
0,0,0,0,'H',0,'I',0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,'J',0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}
root=createbtree(data,1,63)
printf("二叉树的顺序存储内容:\n")
for(i=1i<64i++)
{
if(data[i]==0)
{
printf("^ ")
}
else
{
printf("%C ",data[i])
}
if(i % 8 == 7) printf("\n")
}
printf("\n二叉树的先序遍历序列: ")
preorder(root)
printf("\n二叉树的中序遍历序列: ")
inorder(root)
printf("\n二叉树的后序遍历序列: ")
postorder(root)
printf("\n")
return 0
}