第一章 数据结构与算法 1
1.1 数据结构的概念 1
1.1.1 什么是数据结构 1
1.1.2 为什么要学习数据结构 2
1.1.3 数据结构的分类 2
1.2 算法 4
1.2.1 算法的概念 4
1.2.2 算法的分析 5
1.2.3 设计算法的基本步骤 9
1.2.4 数据结构与算法的关系 9
1.2.5 算法设计中所用的语言 10
习题 12
第二章 串 14
2.1 串的概念 14
2.2 串的存贮结构 15
2.3 串的运算 16
2.3.1 串的联接运算 16
2.3.2 求串的长度运算 16
2.3.3 求子串的运算 16
2.3.4 定位运算 17
2.3.5 置换运算 17
2.4 串的模式匹配 18
习题 22
第三章 线性表 23
3.1 线性表的定义及运算 23
3.2 线性表的存贮结构 24
3.3 栈 25
3.3.1 栈的定义及其运算 25
3.3.2 栈的应用 27
3.3.3 多个栈的情况 30
3.4 队列 33
3.4.1 队列的定义及运算 33
3.4.2 队列的顺序表示 34
3.4.3 循环队列 35
习题 36
第四章 链表 39
4.1 线性表的链接分配 39
4.2 链接的栈和队列 45
4.3 可利用空间表 46
4.4 循环链表 47
4.5 多项式加法 48
4.6 等价关系的处理 54
4.7 双重链表和动态存贮管理 58
4.8 广义表 67
习题 69
第五章 数组 72
5.1 数组的顺序分配 72
5.2 稀疏数组 76
5.3 正交链表与稀疏数组 79
习题 83
第六章 树 85
6.1 树和树的存贮结构 85
6.1.1 树的定义 86
6.1.2 基本术语 86
6.1.3 树的存贮结构 87
6.2 二叉树 88
6.2.1 二叉树的递归定义 88
6.2.2 二叉树的性质 88
6.2.3 二叉树的存贮结构 92
6.3 遍历二叉树 93
6.3.1 前序遍历 94
6.3.2 中序遍历 94
6.3.3 后序遍历 97
6.4 线索二叉树 97
6.5 对一般树及森林的研究 103
6.5.1 一般树的二叉树表示 103
6.5.2 森林的二叉树表示 105
6.5.3 树和森林的遍历 106
6.5.4 树的其它表示法 107
6.6 树的路径长度及哈夫曼算法 111
6.6.1 树的路径长度 111
6.6.2 哈夫曼树 114
6.7 树的应用 117
6.7.1 集合的表示法 117
6.7.2 判定树 121
习题 123
第七章 图 125
7.1 图的基本概念 125
7.2 图的存贮结构 128
7.2.1 图的矩阵表示 128
7.2.2 图的邻接表表示 130
7.2.3 图的其它表示形式 132
7.3 图的遍历和求图的连通分量 134
7.3.1 图的遍历 134
7.3.2 求图的连通分量 138
7.4 有向图的处理 138
7.4.1 单源最短路径 139
7.4.2 每对结点之间的最短路径 142
7.4.3 拓扑排序 143
7.4.4 关键路径 146
7.5 无向图的处理 149
习题 152
第八章 内部排序 154
8.1 插入排序 154
8.2 归并排序 156
8.3 快速排序 161
8.4 选择排序 164
8.5 堆排序 168
8.6 基数排序 172
8.7 各种内排序方法比较 175
习题 175
第九章 外部排序 177
9.1 外部设备简介 177
9.1.1 磁带 177
9.1.2 磁盘 178
9.2 2—路平衡归并排序 178
9.3 多路平衡归并排序 181
9.4 多阶段归并排序 182
9.5 初始归并段的产生 184
9.6 最佳归并排序 187
习题 189
第十章 数据查找 190
10.1 查找及其效率 190
10.2 顺序查找 191
10.3 二分查找 192
10.4 二叉排序树查找 195
10.5 哈希查找 197
10.5.1 哈希函数的构造技术 198
10.5.2 哈希冲突的处理方法 200
10.5.3 哈希法的分析 205
10.6 分块查找 206
习题 210
第十一章 文件 211
11.1 文件的基本概念 211
11.1.1 术语 211
11.1.2 文件的存贮与组织 212
11.2 顺序文件 213
11.3 随机组织文件 215
11.3.1 直接存取文件 215
11.3.2 索引文件 217
11.3.3 链表文件 222
11.4 B-树 223
习题 226
第十二章 数据结构示例 228
参考文献 250