第1章 概论 1
1.1 引言 1
1.2 基本概念和常用术语 4
1.3 算法的描述和分析 7
1.3.1 算法描述 8
1.3.2 算法分析 9
思考题 13
习题1 13
第2章 线性表 16
2.1 线性表的定义和基本运算 16
2.1.1 线性表的逻辑定义 16
2.1.2 线性表的基本运算 17
2.2 线性表的顺序存储和基本运算的实现 19
2.2.1 线性表的顺序存储 19
2.2.2 顺序表上基本运算的实现 20
2.3 线性表的链式存储结构 25
2.3.1 单链表(线性链表) 25
2.3.2 单链表上的基本运算 26
2.3.3 循环链表 34
2.3.4 双向循环链表 35
2.4 顺序表和链表的比较 38
思考题 39
习题2 39
上机实验 42
第3章 栈和队列 43
3.1 栈 43
3.1.1 栈的定义及其基本运算 43
3.1.2 栈的存储表示和实现 44
3.2 栈的应用举例 49
3.2.1 圆括号匹配的检验 49
3.2.2 字符串回文的判断 50
3.2.3 数制转换 51
3.2.4 栈与递归 52
3.3 队列 55
3.3.1 队列的定义及其运算 55
3.3.2 顺序循环队列 56
3.3.3 链队列 61
3.4 栈和队列的应用实例——表达式求值 65
3.4.1 中缀表达式到后缀表达式的转换 66
3.4.2 后缀表达式的计算 69
思考题 71
习题3 71
上机实验 74
第4章 串 75
4.1 串的定义及其运算 75
4.1.1 串的基本概念 75
4.1.2 串的基本运算 76
4.2 串的存储表示和操作的实现 78
4.2.1 串的顺序存储 78
4.2.2 串的链式存储 79
4.2.3 串运算的实现 80
4.3 串运算的应用举例 84
思考题 86
习题4 87
第5章 多维数组和广义表 89
5.1 多维数组及其运算 89
5.1.1 数组的顺序存储 90
5.1.2 数组运算举例 91
5.2 矩阵的压缩存储 92
5.2.1 特殊矩阵 92
5.2.2 稀疏矩阵 95
5.3 广义表 107
5.3.1 广义表的定义 107
5.3.2 广义表的运算 108
5.3.3 广义表的存储结构 109
思考题 110
习题5 110
第6章 树和二叉树 113
6.1 树的基本概念和术语 113
6.2 二叉树 116
6.2.1 二叉树的定义和性质 116
6.2.2 二叉树的存储结构 118
6.3 二叉树的运算 120
6.3.1 二叉树的生成 120
6.3.2 二叉树的遍历 123
6.3.3 二叉树的应用举例 128
6.4 线索二叉树 132
6.4.1 二叉树的线索化 133
6.4.2 二叉线索链表上的运算 135
6.5 树和森林 137
6.5.1 树的存储结构 137
6.5.2 树森林与二叉树的转换 140
6.5.3 树和森林的遍历 142
6.6 赫夫曼树及其应用 143
6.6.1 最优二叉树(赫夫曼树) 143
6.6.2 赫夫曼编码 149
思考题 152
习题6 152
上机实验 155
第7章 图 156
7.1 图的定义和基本术语 156
7.2 图的存储结构 160
7.2.1 邻接矩阵表示法 160
7.2.2 邻接表表示法 162
7.3 图的遍历 165
7.3.1 深度优先搜索 165
7.3.2 广度优先搜索 167
7.4 图的生成树和最小生成树 172
7.4.1 图的生成树 172
7.4.2 最小生成树 173
7.5 最短路径 178
7.6 拓扑排序 182
思考题 186
习题7 186
上机实验 189
第8章 排序 190
8.1 基本概念 190
8.2 插入排序 191
8.2.1 直接插入排序 191
8.2.2 希尔排序 193
8.3 交换排序 194
8.3.1 冒泡排序 195
8.3.2 快速排序 197
8.4 选择排序 201
8.4.1 直接选择排序 202
8.4.2 堆排序 205
8.5 归并排序 209
8.6 基数排序 211
8.7 内部排序方法的分析比较 215
思考题 216
习题8 216
上机实验 219
第9章 查找 220
9.1 基本概念 220
9.2 顺序表的查找 221
9.2.1 顺序查找 221
9.2.2 二分查找 223
9.2.3 索引顺序查找 227
9.2.4 三种查找方法的比较 227
9.3 树表的查找 228
9.3.1 二叉排序树 228
9.3.2 B树 234
9.4 散列表查找 239
9.4.1 散列表的概念 239
9.4.2 散列函数的构造方法 241
9.4.3 处理冲突方法 242
9.4.4 散列表的查找 245
思考题 250
习题9 250
上机实验 253
第10章 文件 254
10.1 基本概念 254
10.2 顺序文件 256
10.3 索引文件 256
10.4 索引顺序文件 258
10.4.1 ISAM文件 258
10.4.2 VSAM文件 259
10.5 散列文件 260
10.6 多关键字文件 260
10.6.1 多重表文件 261
10.6.2 倒排文件 261
思考题 263
习题10 263
附录1 习题参考答案 265
附录2 上机实验参考解答 297
参考文献 365