第1章 绪论 1
1.1什么是数据结构 1
1.2基本概念和术语 4
1.3抽象数据类型的表示与实现 9
1.4算法和算法分析 13
1.4.1算法 13
1.4.2算法设计的要求 13
1.4.3算法效率的度量 14
1.4.4算法的存储空间需求 17
第2章 线性表 18
2.1线性表的类型定义 18
2.2线性表的顺序表示和实现 21
2.3线性表的链式表示和实现 27
2.3.1线性链表 27
2.3.2循环链表 35
2.3.3双向链表 35
2.4一元多项式的表示及相加 39
第3章 栈和队列 44
3.1栈 44
3.1.1抽象数据类型栈的定义 44
3.1.2栈的表示和实现 45
3.2栈的应用举例 48
3.2.1数制转换 48
3.2.2括号匹配的检验 49
3.2.3行编辑程序 49
3.2.4迷宫求解 50
3.2.5表达式求值 52
3.3栈与递归的实现 54
3.4队列 58
3.4.1抽象数据类型队列的定义 58
3.4.2链队列——队列的链式表示和实现 60
3.4.3循环队列——队列的顺序表示和实现 63
3.5离散事件模拟 65
第4章串 70
4.1串类型的定义 70
4.2串的表示和实现 72
4.2.1定长顺序存储表示 73
4.2.2堆分配存储表示 75
4.2.3串的块链存储表示 78
4.3串的模式匹配算法 79
4.3.1求子串位置的定位函数Index (S, T,pos) 79
4.3.2模式匹配的一种改进算法 80
4.4串操作应用举例 84
4.4.1文本编辑 84
4.4.2建立词索引表 86
第5章 数组和广义表 90
5.1数组的定义 90
5.2数组的顺序表示和实现 91
5.3矩阵的压缩存储 95
5.3.1特殊矩阵 95
5.3.2稀疏矩阵 96
5.4广义表的定义 106
5.5广义表的存储结构 109
5.6 m元多项式的表示 110
5.7广义表的递归算法 112
5.7.1求广义表的深度 113
5.7.2复制广义表 115
5.7.3建立广义表的存储结构 115
第6章 树和二叉树 118
6.1树的定义和基本术语 118
6.2二叉树 121
6.2.1二叉树的定义 121
6.2.2二叉树的性质 123
6.2.3二叉树的存储结构 126
6.3遍历二叉树和线索二叉树 128
6.3.1遍历二叉树 128
6.3.2线索二叉树 132
6.4树和森林 135
6.4.1树的存储结构 135
6.4.2森林与二叉树的转换 137
6.4.3树和森林的遍历 138
6.5树与等价问题 139
6.6赫夫曼树及其应用 144
6.6.1最优二叉树(赫夫曼树) 144
6.6.2赫夫曼编码 146
6.7回溯法与树的遍历 149
6.8树的计数 152
第7章图 156
7.1图的定义和术语 156
7.2图的存储结构 160
7.2.1数组表示法 161
7.2.2邻接表 163
7.2.3十字链表 164
7.2.4邻接多重表 166
7.3图的遍历 167
7.3.1深度优先搜索 167
7.3.2广度优先搜索 169
7.4图的连通性问题 170
7.4.1无向图的连通分量和生成树 170
7.4.2有向图的强连通分量 172
7.4.3最小生成树 173
7.4.4关节点和重连通分量 176
7.5有向无环图及其应用 179
7.5.1拓扑排序 180
7.5.2关键路径 183
7.6最短路径 186
7.6.1从某个源点到其余各顶点的最短路径 187
7.6.2每一对顶点之间的最短路径 190
第8章 动态存储管理 193
8.1概述 193
8.2可利用空间表及分配方法 195
8.3边界标识法 198
8.3.1可利用空间表的结构 198
8.3.2分配算法 199
8.3.3回收算法 201
8.4伙伴系统 203
8.4.1可利用空间表的结构 203
8.4.2分配算法 204
8.4.3回收算法 205
8.5无用单元收集 206
8.6存储紧缩 212
第9章查找 214
9.1静态查找表 216
9.1.1顺序表的查找 216
9.1.2有序表的查找 218
9.1.3静态树表的查找 222
9.1.4索引顺序表的查找 225
9.2动态查找表 226
9.2.1二叉排序树和平衡二叉树 227
9.2.2 B-树和B+树 238
9.2.3键树 247
9.3哈希表 251
9.3.1什么是哈希表 251
9.3.2哈希函数的构造方法 253
9.3.3处理冲突的方法 256
9.3.4哈希表的查找及其分析 259
第10章 内部排序 263
10.1概述 263
10.2插入排序 265
10.2.1直接插入排序 265
10.2.2其他插入排序 266
10.2.3希尔排序 271
10.3快速排序 272
10.4选择排序 277
10.4.1简单选择排序 277
10.4.2树形选择排序 278
10.4.3堆排序 279
10.5归并排序 283
10.6基数排序 284
10.6.1多关键字的排序 284
10.6.2链式基数排序 286
10.7各种内部排序方法的比较讨论 288
第11章 外部排序 293
11.1外存信息的存取 293
11.2外部排序的方法 295
11.3多路平衡归并的实现 297
11.4置换-选择排序 299
11.5最佳归并树 304
第12章 文件 306
12.1有关文件的基本概念 306
12.2顺序文件 308
12.3索引文件 311
12.4 ISAM文件和VSAM文件 313
12.4.1 ISAM文件 313
12.4.2 VSAM文件 316
12.5直接存取文件(散列文件) 317
12.6多关键字文件 319
12.6.1多重表文件 319
12.6.2倒排文件 319
附录A名词索引 322
附录B函数索引 329
参考书目 334