第1章 概论 1
1.1 引言 1
1.2 基本概念和常用术语 2
1.3 算法的描述和分析 3
1.3.1 算法描述 3
1.3.2 算法分析 4
习题 6
第2章 线性表 8
2.1 线性表的定义和基本运算 8
2.1.1 线性表的逻辑定义 8
2.1.2 线性表的基本运算 9
2.2 线性表的顺序存储及基本运算的实现 10
2.2.1 顺序表 10
2.2.2 顺序表上基本运算的实现 11
2.3 线性表的链式存储结构 14
2.3.1 单链表 14
2.3.2 单链表上的基本运算 16
2.3.3 循环链表 23
2.3.4 双向链表 24
习题 26
第3章 栈和队列 29
3.1 栈 29
3.1.1 栈的定义和基本运算 29
3.1.2 栈的存储表示和实现 30
3.2 栈的应用举例 34
3.2.1 圆括号匹配的检验 34
3.2.2 字符串回文的判断 35
3.2.3 数制转换 35
3.2.4 栈与递归 36
3.3 队列 39
3.3.1 队列的定义及运算 39
3.3.2 顺序队列 40
3.3.3 链队列 43
习题 47
第4章 串 50
4.1 串的定义及其运算 50
4.1.1 串的基本概念 50
4.1.2 串的基本运算 51
4.2 串的存储表示和操作的实现 52
4.2.1 串的顺序存储 52
4.2.2 串的链式存储 53
4.2.3 串运算的实现 53
4.3 串运算的应用举例 55
习题 57
第5章 多维数组和广义表 59
5.1 多维数组及其运算 59
5.1.1 数组的顺序存储 59
5.1.2 数组运算举例 60
5.2 矩阵的压缩存储 61
5.2.1 特殊矩阵 61
5.2.2 稀疏矩阵 64
5.3 广义表 67
5.3.1 广义表的定义 67
5.3.2 广义表的存储结构 68
习题 70
第6章 树 72
6.1 树的概念和术语 72
6.2 二叉树 74
6.2.1 二叉树的概念 74
6.2.2 二叉树的存储结构 75
6.3 二叉树的运算 77
6.3.1 二叉树的生成 77
6.3.2 二叉树的遍历 78
6.3.3 二叉树的其他操作举例 83
6.4 线索二叉树 85
6.4.1 二叉树的线索化 86
6.4.2 二叉线索链表上的运算 88
6.5.1 树的存储结构 89
6.5 树和森林 89
6.5.2 树、森林与二叉树的转换 91
6.5.3 树和森林的遍历 93
6.6 哈夫曼树及其应用 93
6.6.1 基本术语 94
6.6.2 最优二叉树(哈夫曼树) 94
6.6.3 哈夫曼编码 98
习题 99
第7章 图 102
7.1 图的定义和基本术语 102
7.2 图的存储结构 104
7.2.1 邻接矩阵表示法 104
7.2.2 邻接表表示法 106
7.3 图的遍历 107
7.3.1 深度优先搜索遍历 108
7.3.2 广度优先搜索遍历 110
7.4.1 图的生成树 113
7.4 图的生成树和最小生成树 113
7.4.2 最小生成树 115
7.5 最短路径 118
7.6 拓扑排序 121
习题 124
第8章 排序 128
8.1 概述 128
8.2 插入排序 129
8.2.1 直接插入排序 129
8.2.2 希尔排序 130
8.3 交换排序 131
8.3.1 起泡排序(冒泡) 132
8.3.2 快速排序 133
8.4 选择排序 136
8.4.1 直接选择排序 137
8.4.2 堆排序 138
8.5 归并排序 142
8.6 分配排序 144
8.6.1 箱排序 144
8.6.2 基数排序 145
8.7 内部排序方法的分析比较 147
习题 148
第9章 查找 152
9.1 基本概念 152
9.2 顺序表的查找 152
9.2.1 顺序查找 153
9.2.2 二分查找 153
9.2.3 索引顺序查找 157
9.3 树表的查找 157
9.3.1 二叉排序树 157
9.3.2 B-树 162
9.4 散列表查找 166
9.4.1 散列表的概念 166
9.4.2 散列函数的构造方法 167
9.4.3 处理冲突的方法 168
9.4.4 散列表的查找 170
习题 175
第10章 文件 178
10.1 基本概念 178
10.2 顺序文件 179
10.3 索引文件 179
10.4 索引顺序文件 181
10.4.1 ISAM文件 181
10.4.2 VSAM文件 181
10.5 散列文件 182
10.6 多关键字文件 183
10.6.1 多重表文件 183
10.6.2 倒排文件 184
习题 185
参考文献 187