第1章 绪论 1
1.1 什么是数据结构 1
1.1.1 逻辑结构 1
1.1.2 存储结构 2
1.1.3 数据运算 3
1.2 算法和算法分析 4
1.2.1 算法及其表示 4
1.2.2 算法分析 5
练习题及参考答案1 7
第2章 线性表 11
2.1 线性表的基本概念 11
2.1.1 线性结构 11
2.1.2 线性表及其基本运算 11
2.2 线性表的顺序实现 13
2.2.1 顺序表 13
2.2.2 基本运算在顺序表上的实现 14
2.2.3 顺序实现的算法分析 16
2.3 单链表的表示和实现 18
2.3.1 单链表 18
2.3.2 基本运算在单链表上的实现 18
2.3.3 循环单链表 22
2.4 双链表的表示和实现 28
2.4.1 双链表 28
2.4.2 基本运算在双链表上的实现 28
2.4.3 循环双链表 32
2.5 链表的应用 36
练习题及参考答案2 41
第3章 栈和队列 51
3.1 栈 51
3.1.1 栈的基本概念 51
3.1.2 栈的顺序实现 53
3.1.3 栈的链式实现 56
3.2 队列 60
3.2.1 队列的基本概念 60
3.2.2 队列的顺序实现 61
3.2.3 队列的链式实现 65
练习题及参考答案3 70
第4章 串 80
4.1 串的基本概念 80
4.1.1 串 80
4.1.2 串的基本运算 81
4.2 串的顺序存储 82
4.2.1 顺序串 82
4.2.2 基本运算在顺序串上的实现 83
4.3 串的链接存储 88
4.3.1 链串 88
4.3.2 基本运算在链串上的实现 89
4.4 串的模式匹配 94
4.4.1 Brute-Force算法 95
4.4.2 KMP算法 96
练习题及参考答案4 100
第5章 数组和广义表 106
5.1 数组 106
5.1.1 数组的基本概念 106
5.1.2 数组的存储结构 107
5.1.3 特殊矩阵的压缩存储 109
5.1.4 稀疏矩阵 111
5.2 广义表 121
5.2.1 广义表的定义 121
5.2.2 广义表的存储结构 122
5.2.3 广义表的运算 124
练习题及参考答案5 130
第6章 树和二叉树 138
6.1 树的基本概念 138
6.1.1 树的定义 138
6.1.2 树的基本术语 138
6.1.3 树的逻辑表示方法 139
6.1.4 树的性质 140
6.1.5 树的基本运算 141
6.1.6 树的存储结构 142
6.2 二叉树概念和性质 145
6.2.1 二叉树概念 145
6.2.2 二叉树性质 146
6.2.3 二叉树与树、森林之间的转换 147
6.3 二叉树存储结构 149
6.3.1 二叉树的顺序存储结构 149
6.3.2 二叉树的链式存储结构 150
6.4 二叉树的基本运算及其实现 151
6.4.1 二叉树的基本运算概述 151
6.4.2 二叉树的基本运算算法实现 151
6.5 二叉树的遍历 154
6.5.1 二叉树遍历的概念 154
6.5.2 二叉树遍历算法的实现 155
6.6 线索二叉树 158
6.6.1 线索二叉树的概念 158
6.6.2 线索化二叉树 159
6.7 哈夫曼树 162
6.7.1 路径长度和哈夫曼树 162
6.7.2 哈夫曼树的构造算法 163
6.7.3 哈夫曼编码 164
练习题及参考答案6 165
第7章 图 179
7.1 图的基本概念 179
7.1.1 图的定义 179
7.1.2 图的基本术语 180
7.2 图的存储结构 182
7.2.1 邻接矩阵存储方法 182
7.2.2 邻接表存储方法 184
7.2.3 十字邻接表存储方法 185
7.2.4 邻接多重表存储方法 186
7.3 图的遍历 188
7.3.1 图的遍历的概念 188
7.3.2 深度优先搜索遍历 189
7.3.3 广度优先搜索遍历 189
7.3.4 非连通图的遍历 190
7.4 生成树和最小生成树 192
7.4.1 生成树的概念 192
7.4.2 无向图的连通分量和生成树 193
7.4.3 有向图的强连通分量 194
7.4.4 普里姆算法 195
7.4.5 克鲁斯卡尔算法 196
7.5 最短路径 198
7.5.1 路径的概念 198
7.5.2 从一个顶点到其余各顶点的最短路径 198
7.5.3 每对顶点之间的最短路径 202
7.6 拓扑排序 205
7.7 AOE网与关键路径 208
练习题及参考答案7 211
第8章 查找 224
8.1 查找的基本概念 224
8.2 线性表的查找 225
8.2.1 顺序查找 225
8.2.2 二分查找 226
8.2.3 分块查找 228
8.3 树表的查找 231
8.3.1 二叉排序树 231
8.3.2 平衡二叉树 237
8.3.3 B-树 241
8.3.4 B+树 245
8.4 哈希表查找 248
8.4.1 哈希表的基本概念 248
8.4.2 哈希函数构造方法 248
8.4.3 哈希冲突解决方法 249
练习题及参考答案8 254
第9章 内排序 266
9.1 排序的基本概念 266
9.2 插入排序 267
9.2.1 直接插入排序 267
9.2.2 希尔排序 269
9.3 交换排序 270
9.3.1 冒泡排序 270
9.3.2 快速排序 272
9.4 选择排序 274
9.4.1 直接选择排序 274
9.4.2 堆排序 275
9.5 归并排序 279
9.6 基数排序 281
练习题及参考答案9 283
第10章 外排序 291
10.1 外排序概述 291
10.2 磁盘排序 291
10.2.1 磁盘排序过程 291
10.2.2 多路平衡归并 293
10.2.3 初始归并段的生成 294
10.2.4 最佳归并树 296
10.3 磁带排序 298
10.3.1 多路平衡归并排序 298
10.3.2 多阶段归并排序 299
练习题及参考答案10 301
第11章 文件 303
11.1 文件的基本概念 303
11.1.1 什么是文件 303
11.1.2 文件的逻辑结构及操作 304
11.1.3 文件的存储结构 304
11.2 顺序文件 304
11.3 索引文件 305
11.3.1 ISAM文件 306
11.3.2 VSAM文件 307
11.4 散列文件 308
11.5 多关键字文件 309
11.5.1 多重表文件 309
11.5.2 倒排文件 310
练习题及参考答案11 311
附录A 一份全真《数据结构》研究生入学考试试题及参考答案 314
附录B 本书程序使用的C++语法说明 321
参考文献 322