第1章 绪论 1
1.1 数据结构的概念 1
1.1.1 基本概念和术语 1
1.1.2 逻辑结构 2
1.1.3 存储结构 4
1.1.4 抽象数据类型 5
1.2 算法 7
1.2.1 算法的描述 7
1.2.2 算法设计的要求 7
1.2.3 算法分析 7
第2章 线性表 12
2.1 线性表的抽象数据类型 12
2.2 线性表的顺序存储结构 14
2.2.1 顺序表的类型定义 15
2.2.2 线性表基本运算在顺序表上的实现 15
2.2.3 顺序实现的算法分析 17
2.2.4 顺序表的应用举例 17
2.3 线性表的链式存储结构 19
2.3.1 单链表 19
2.3.2 单循环链表 26
2.3.3 双向链表 27
第3章 栈 31
3.1 栈的抽象数据类型 31
3.2 栈的顺序存储结构 33
3.2.1 顺序栈的类型定义 33
3.2.2 栈基本运算在顺序栈上的实现 34
3.2.3 顺序栈的应用举例 35
3.3 栈的链式存储结构 36
3.3.1 链栈的类型定义 37
3.3.2 栈基本运算在链栈上的实现 37
3.3.3 链栈的应用举例 38
3.4 栈与递归的实现 39
第4章 队列 42
4.1 队列的抽象数据类型 42
4.2 队列的顺序存储结构 44
4.2.1 循环队列的类型定义 45
4.2.2 队列基本运算在循环队列上的实现 45
4.2.3 循环队列的应用举例 46
4.3 队列的链式存储结构 47
4.3.1 链队列的类型定义 47
4.3.2 队列基本运算在链队列上的实现 48
4.3.3 链队列的应用举例 49
第5章 数组和稀疏矩阵 52
5.1 数组的概念与表示 52
5.1.1 数组的概念 52
5.1.2 数组的顺序表示 54
5.1.3 特殊矩阵的压缩存储 56
5.2 稀疏矩阵 57
5.2.1 稀疏矩阵的三元组表示 58
5.2.2 稀疏矩阵的十字链表表示 65
第6章 树和二叉树 69
6.1 树 69
6.1.1 树的定义和表示 69
6.1.2 树的基本术语和操作 71
6.1.3 树的存储结构 73
6.2 二叉树 76
6.2.1 二叉树的定义 76
6.2.2 二叉树的性质 79
6.2.3 二叉树的存储结构 81
6.3 二叉树的遍历 83
6.3.1 常用的二叉树遍历算法 83
6.3.2 遍历算法的应用 90
6.4 树和森林 92
6.4.1 森林转换为二叉树 92
6.4.2 二叉树转换为森林 93
6.4.3 树的遍历 94
6.4.4 森林的遍历 95
6.5 哈夫曼树及其应用 96
6.5.1 哈夫曼树 96
6.5.2 哈夫曼算法 97
6.5.3 哈夫曼编码 99
第7章 图 104
7.1 图的基本概念 104
7.1.1 图的抽象数据类型的定义 104
7.1.2 图的基本术语 106
7.2 图的存储结构 108
7.2.1 邻接矩阵 108
7.2.2 邻接表 110
7.3 图的遍历 112
7.3.1 深度优先搜索 112
7.3.2 广度优先搜索 114
7.4 最小生成树 115
7.4.1 普里姆算法 116
7.4.2 克鲁斯卡尔算法 119
7.5 拓扑排序 121
7.6 关键路径 124
7.7 最短路径 129
7.7.1 单源点最短路径 129
7.7.2 每对顶点之间的最短路径 131
第8章 查找 135
8.1 查找表 135
8.2 静态查找表 136
8.2.1 顺序查找 136
8.2.2 折半查找 137
8.2.3 分块查找 138
8.3 动态查找表 139
8.3.1 二叉排序树 139
8.3.2 平衡二叉树 143
8.4 哈希表 146
8.4.1 哈希函数的构造方法 146
8.4.2 哈希冲突的解决方法 147
第9章 排序 152
9.1 排序的基本概念 152
9.2 插入排序 153
9.2.1 直接插入排序 153
9.2.2 希尔排序 154
9.3 交换排序 156
9.3.1 冒泡排序 156
9.3.2 快速排序 157
9.4 选择排序 159
9.4.1 直接选择排序 159
9.4.2 堆排序 159
9.5 归并排序 161
9.6 基数排序 162
附录A 实验安排 167
附录B 中英名词对照表 169
参考文献 171