推荐《数据结构》(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
}
严蔚敏的《数据结构(C语言版)》这本书在豆瓣评分挺高的。数据结构(C语言版)的具体内容:
数据结构分为8类有:数组、栈、队列、链表、树、散列表、堆、图。数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成 。
1、数组
数组是可以再内存中连续存储多个元素的结构,在内存中的分配也是连续的,数组中的元素通过数组下标进行访问,数组下标从0开始。例如下面这段代码就是将数组的第一个元素赋值为 1。
2、栈
栈是一种特殊的线性表,仅能在线性表的一端操作,栈顶允许操作,栈底不允许操作。 栈的特点是:先进后出,或者说是后进先出,从栈顶放入元素的操作叫入栈,取出元素叫出栈。
3、队列
队列与栈一样,也是一种线性表,不同的是,队列可以在一端添加元素,在另一端取出元素,也就是:先进先出。从一端放入元素的操作称为入队,取出元素为出队。
4、链表
链表是物理存储单元上非连续的、非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,每个元素包含两个结点,一个是存储元素的数据域 (内存空间),另一个是指向下一个结点地址的指针域。根据指针的指向,链表能形成不同的结构,例如单链表,双向链表,循环链表等。