第1章 绪论 1
1.1 数据结构的概念 1
1.1.1 引言 1
1.1.2 数据结构有关概念与术语 4
1.2 抽象数据类型 6
1.3 算法描述与分析 7
1.3.1 什么是算法 7
1.3.2 算法分析技术 8
1.4 小结 11
讨论小课堂 12
习题 12
第2章 线性表 14
2.1 线性表的定义及其运算 14
2.1.1 线性表的定义 14
2.1.2 线性表的基本操作 14
2.2 线性表的顺序存储结构及实现 15
2.2.1 顺序存储结构 15
2.2.2 线性表在向量中基本运算的实现 17
2.3 线性表的链表存储结构 21
2.3.1 单链表 22
2.3.2 线性链表基本运算的实现 24
2.4 循环链表和双向链表 30
2.4.1 循环链表 30
2.4.2 双向链表 31
2.4.3 顺序存储结构与链表存储结构的综合分析与比较 33
2.5 单链表的应用 33
2.5.1 多项式相加的链表存储结构 34
2.5.2 多项式相加的算法实现 34
2.6 小结 35
讨论小课堂 36
习题 37
第3章 栈和队列 39
3.1 栈 39
3.1.1 栈的定义 39
3.1.2 栈的基本操作 40
3.2 栈的顺序存储结构及实现 41
3.2.1 栈的顺序存储结构 41
3.2.2 顺序栈的类定义 42
3.3 栈的链表存储结构及实现 44
3.4 栈的应用 46
3.4.1 表达式的计算 46
3.4.2 子程序的嵌套调用 48
3.4.3 递归调用 49
3.4.4 n阶Hanoi塔问题 50
3.5 队列 51
3.5.1 队列的定义及运算 51
3.5.2 队列的抽象数据类型描述 52
3.6 队列的顺序存储结构及实现 52
3.7 队列的链表存储结构及实现 55
3.8 队列的应用 58
3.9 小结 59
讨论小课堂 60
习题 60
第4章 串 62
4.1 串的基本概念 62
4.1.1 串的定义 62
4.1.2 串的基本操作 63
4.2 串的存储与基本操作的实现 65
4.2.1 定长顺序串 65
4.2.2 堆串 66
4.2.3 块链串 66
4.2.4 串操作的实现 67
4.3 串的模式匹配 70
4.3.1 朴素模式匹配算法 71
4.3.2 模式匹配的KMP算法 71
4.4 串的应用举例:文本编辑 76
4.5 小结 77
讨论小课堂 78
习题 78
第5章 数组和广义表 80
5.1 数组的定义及运算 80
5.1.1 数组的定义 80
5.1.2 数组的基本操作 81
5.2 数组的存储结构 81
5.3 特殊矩阵的压缩存储 82
5.3.1 对称矩阵 83
5.3.2 三角矩阵 84
5.3.3 对角矩阵 85
5.4 稀疏矩阵的压缩存储 86
5.4.1 稀疏矩阵的顺序存储结构——三元组顺序表 86
5.4.2 稀疏矩阵的链式存储结构 89
5.5 广义表 92
5.5.1 广义表的定义和基本运算 92
5.5.2 广义表的存储 93
5.6 小结 95
讨论小课堂 96
习题 96
第6章 树与二叉树 98
6.1 树的概念及术语 98
6.1.1 树的定义 99
6.1.2 树的基本操作 100
6.1.3 树的表示方式 100
6.2 二叉树 101
6.2.1 二叉树的定义 101
6.2.2 二叉树的重要性质 101
6.2.3 二叉树的存储结构 102
6.3 二叉树的遍历 104
6.3.1 先序遍历 105
6.3.2 中序遍历 105
6.3.3 后根遍历 106
6.3.4 按层遍历 107
6.3.5 非递归遍历算法 107
6.3.6 二叉树的建立 109
6.3.7 二叉树遍历的应用举例 111
6.4 二叉树与树、森林的转换 112
6.4.1 树与二叉树的转换 112
6.4.2 森林与二叉树的转换 113
6.5 树的存储结构 114
6.5.1 树的双亲表示法 115
6.5.2 孩子表示法 115
6.5.3 孩子-兄弟表示法 115
6.6 树的遍历 116
6.6.1 一般树的遍历 116
6.6.2 森林的遍历 118
6.7 二叉树的应用 118
6.7.1 哈夫曼树 118
6.7.2 哈夫曼树的构造 119
6.7.3 哈夫曼树的实现算法 119
6.7.4 哈夫曼编码 121
6.8 小结 121
讨论小课堂 122
习题 122
第7章 图 125
7.1 图的基本概念 125
7.1.1 图的定义 125
7.1.2 图的术语 126
7.1.3 图的基本操作 128
7.2 图的存储结构 129
7.2.1 图的邻接矩阵 129
7.2.2 邻接矩阵表示法的C语言类型描述 131
7.2.3 邻接矩阵表示法的基本操作的实现 132
7.2.4 图的邻接链表 133
7.2.5 图的邻接表表示法的C语言类型描述 134
7.2.6 建立图的邻接表函数和输出图的信息函数 135
7.3 图的遍历与图的连通性 137
7.3.1 图的深度优先遍历 137
7.3.2 图的广度优先遍历 140
7.3.3 非连通图和连通分量 141
7.4 图的最小生成树 142
7.4.1 最小生成树的基本概念 142
7.4.2 普里姆算法 143
7.4.3 克鲁斯卡尔算法 145
7.5 最短路径 146
7.5.1 从某顶点到其余各顶点的最短路径 146
7.5.2 每对顶点之间的最短路径 149
7.6 拓扑排序与关键路径 151
7.6.1 拓扑排序 151
7.6.2 关键路径 154
7.7 图的应用 159
7.7.1 图在路由器寻径中的应用 160
7.7.2 图在物流信息系统中应用 160
7.8 小结 161
讨论小课堂 161
习题 162
第8章 查找 163
8.1 概述 163
8.2 静态查找表 164
8.2.1 顺序查找 164
8.2.2 折半查找 165
8.2.3 分块查找 166
8.3 动态查找表 168
8.3.1 二叉排序树 168
8.3.2 平衡二叉树 173
8.4 小结 176
讨论小课堂 176
习题 176
第9章 排序 178
9.1 排序的基本概念 178
9.2 插入排序 179
9.2.1 直接插入排序 179
9.2.2 折半插入排序 180
9.2.3 希尔排序 180
9.3 交换排序 182
9.3.1 冒泡排序 182
9.3.2 快速排序 183
9.4 选择排序 186
9.4.1 简单选择排序 186
9.4.2 堆排序 187
9.5 归并排序 190
9.6 基数排序 192
9.7 小结 195
讨论小课堂 196
习题 197
第10章 索引结构与散列 198
10.1 静态索引结构 198
10.1.1 索引表 198
10.1.2 索引表查找 198
10.2 动态索引结构(B-树和B+树) 200
10.2.1 B-树的定义 201
10.2.2 B-树的运算 202
10.2.3 B+树 204
10.3 键树及Trie树 205
10.3.1 键树的定义 205
10.3.2 双链树 206
10.3.3 Trie树 207
10.4 哈希表及其查找 208
10.4.1 哈希表与哈希函数 208
10.4.2 构造哈希函数的常用方法 209
10.4.3 解决冲突的主要方法 211
10.4.4 哈希查找的性能分析 215
10.5 小结 216
讨论小课堂 216
习题 217
附录 上机实验指导 220
第1部分 上机实验要求及规范 220
第2部分 实验部分 221
实验1 复数ADT及其实现 221
实验2 线性表 223
实验3 栈和队列 230
实验4 串 235
实验5 数组 237
实验6 树与二叉树 239
实验7 图 243
实验8 查找 247
实验9 排序 249
实验10 哈希查找 254
参考文献 257