第1章 绪论 1
1.1 数据结构的研究对象 1
1.2 数据结构的发展概况 4
1.3 基本概念与术语 4
1.4 数据类型与抽象数据类型 6
1.4.1 数据类型 6
1.4.2 抽象数据类型 6
1.4.3 抽象数据类型的表示与实现 7
1.5 算法与算法分析 9
1.5.1 算法 9
1.5.2 算法设计的原则 10
1.5.3 算法效率的衡量方法和准则 10
1.5.4 算法的存储空间需求 12
1.6 典型例题 12
1.7 上机实验 13
习题 13
第2章 线性表 16
2.1 线性表的定义 16
2.1.1 线性表的概念 16
2.1.2 线性表的抽象数据类型定义 16
2.2 线性表的顺序表示与实现 17
2.2.1 线性表的顺序表示 17
2.2.2 线性表的顺序实现 18
2.2.3 顺序表的应用举例 21
2.3 线性表的链式表示与实现 22
2.3.1 单链表 22
2.3.2 双向链表 26
2.3.3 循环链表 29
2.3.4 静态链表 31
2.3.5 链表的应用举例 33
2.4 典型例题 35
2.5 上机实验 37
习题 39
第3章 栈与队列 41
3.1 栈 41
3.1.1 栈的抽象数据类型定义 41
3.1.2 栈的表示与实现 42
3.2 栈的应用举例 44
3.2.1 数制转换 44
3.2.2 括号匹配的检验 45
3.2.3 表达式求值 46
3.2.4 求命题公式的真值 50
3.3 栈与递归实现 53
3.3.1 递归的定义 53
3.3.2 递归与栈的关系 53
3.3.3 递归的实现 54
3.3.4 用递归求所有出栈序列 56
3.3.5 递归的消除 57
3.4 队列 59
3.4.1 队列的抽象数据类型定义 59
3.4.2 队列的链式表示与实现 60
3.4.3 队列的顺序表示与实现——循环队列 61
3.4.4 队列的应用举例 63
3.5 典型例题 64
3.6 上机实验 66
习题 68
第4章 串 70
4.1 串的定义 70
4.2 串的表示与实现 72
4.2.1 串的顺序存储表示 72
4.2.2 串的链式存储表示 75
4.3 串的模式匹配 75
4.3.1 简单匹配算法 75
4.3.2 首尾匹配算法 77
4.3.3 KMP算法 78
4.4 典型例题 80
4.5 上机实验 82
习题 83
第5章 数组与广义表 85
5.1 数组的定义 85
5.2 数组的顺序存储 86
5.3 矩阵的压缩存储 88
5.3.1 特殊矩阵 89
5.3.2 稀疏矩阵 90
5.4 广义表 94
5.4.1 广义表的定义 94
5.4.2 广义表的存储结构 96
5.5 典型例题 98
5.6 上机实验 99
习题 100
第6章 树与二叉树 101
6.1 树的定义 101
6.1.1 树的概念与术语 101
6.1.2 树的逻辑表示方法 102
6.1.3 树的抽象数据类型定义 102
6.2 二叉树的定义 103
6.2.1 二叉树的概念 103
6.2.2 二叉树的重要性质 105
6.3 二叉树的存储结构 106
6.3.1 二叉树的顺序存储表示 106
6.3.2 二叉树的链式存储表示 106
6.4 二叉树的遍历 108
6.4.1 二叉树遍历的概念 108
6.4.2 二叉树遍历的递归算法 108
6.4.3 二叉树遍历的非递归算法 109
6.4.4 层次遍历算法 111
6.4.5 遍历算法的应用举例 112
6.5 二叉树的构造 115
6.6 线索二叉树 116
6.6.1 线索二叉树的定义 116
6.6.2 线索链表的建立 117
6.6.3 线索链表的遍历算法 118
6.7 树和森林的表示方法 119
6.7.1 双亲表示法 119
6.7.2 孩子链表表示法 120
6.7.3 孩子-兄弟链表表示法 121
6.7.4 树、森林和二叉树的对应关系 121
6.8 树和森林的遍历 122
6.8.1 树的遍历 122
6.8.2 森林的遍历 123
6.8.3 树遍历算法的应用 124
6.9 赫夫曼树与赫夫曼编码 124
6.9.1 赫夫曼树的定义 125
6.9.2 赫夫曼树的构造 125
6.9.3 赫夫曼编码 127
6.10 典型例题 128
6.11 上机实验 130
习题 130
第7章 图 133
7.1 图的定义与术语 133
7.1.1 图的相关术语 133
7.1.2 图的抽象数据类型定义 135
7.2 图的存储表示 136
7.2.1 图的邻接矩阵存储表示 136
7.2.2 图的邻接表存储表示 137
7.2.3 有向图的十字链表存储表示 138
7.2.4 无向图的邻接多重表存储表示 140
7.3 图的遍历 141
7.3.1 深度优先搜索遍历图 141
7.3.2 广度优先搜索遍历图 142
7.3.3 图遍历的应用举例 143
7.4 最小生成树 145
7.4.1 普里姆算法 145
7.4.2 克鲁斯卡尔算法 147
7.5 两点之间的最短路径问题 148
7.5.1 从某个源点到其余各点的最短路径 148
7.5.2 每一对顶点之间的最短路径 150
7.6 拓扑排序 151
7.7 关键路径 153
7.8 典型例题 156
7.9 上机实验 158
习题 160
第8章 查找 162
8.1 基本概念 162
8.2 静态查找表 163
8.2.1 顺序查找 163
8.2.2 有序表查找 164
8.2.3 索引查找 167
8.3 动态查找树表 168
8.3.1 二叉排序树 169
8.3.2 平衡二叉树 173
8.3.3 B-树 179
8.3.4 B+树 183
8.3.5 键树 184
8.4 哈希表 185
8.4.1 哈希表的概念 185
8.4.2 哈希函数的构造方法 185
8.4.3 处理冲突的方法 187
8.4.4 哈希表的查找 189
8.4.5 哈希表的插入操作 190
8.4.6 哈希表的删除操作 191
8.5 典型例题 191
8.6 上机实验 193
习题 194
第9章 排序 196
9.1 概述 196
9.1.1 什么是排序 196
9.1.2 内部排序和外部排序 196
9.1.3 内部排序的方法 197
9.2 插入排序 198
9.2.1 直接插入排序 198
9.2.2 折半插入排序 199
9.2.3 二路插入排序 200
9.2.4 表插入排序 202
9.2.5 希尔排序 204
9.3 交换排序 205
9.3.1 起泡排序 205
9.3.2 快速排序 206
9.4 选择排序 209
9.4.1 简单选择排序 209
9.4.2 堆排序 209
9.5 归并排序 212
9.6 基数排序 213
9.6.1 多关键字排序 213
9.6.2 链式基数排序 214
9.7 各种排序方法的综合比较 216
9.8 外排序简介 217
9.8.1 外存信息的存取 218
9.8.2 外排序的基本方法 218
9.9 典型例题 219
9.10 上机实验 221
习题 222
第10章 文件 224
10.1 文件的基本概念 224
10.1.1 什么是文件 224
10.1.2 文件的逻辑结构及操作 224
10.1.3 文件的存储结构 225
10.2 顺序文件 225
10.3 索引文件 226
10.3.1 ISAM文件 227
10.3.2 VSAM文件 229
10.4 哈希文件 231
10.5 多关键字文件 232
10.5.1 多重表文件 232
10.5.2 倒排文件 232
10.5.3 倒排文件的应用 234
10.6 典型例题 235
10.7 上机实验 237
习题 237
参考文献 239