目录 1
第1章 绪论 1
本章要点 1
1.1 数据结构概念 1
1.1.1 为什么要学习数据结构 1
1.1.2 有关概念和术语 4
1.2 算法描述 7
1.2.1 算法特性 7
1.2.2 算法描述 8
1.3 算法分析 9
小结 10
习题 11
2.1.1 线性表的定义 12
2.1 线性表的逻辑结构 12
本章要点 12
第2章 线性表 12
2.1.2 线性表的基本操作 13
2.2 线性表的顺序存储及操作实现 14
2.2.1 顺序表 14
2.2.2 顺序表的基本操作实现 16
2.2.3 顺序表应用举例 20
2.3 线性表的链式存储和运算实现 22
2.3.1 单链表 22
2.3.2 单链表上基本运算的实现 24
2.3.3 循环链表 30
2.3.4 双向链表 31
2.4 应用举例 33
小结 35
习题 36
3.1.1 栈的定义和基本运算 38
3.1 栈 38
本章要点 38
第3章 栈和队列 38
3.1.2 栈的存储实现和运算实现 39
3.2 栈的应用举例 42
3.3 队列 47
3.3.1 队列的定义和基本运算 47
3.3.2 队列的存储实现和运算实现 48
3.4 队列应用举例 54
小结 55
习题 55
第4章 串和数组 58
本章要点 58
4.1 串 58
4.1.1 串的基本概念 58
4.1.2 串的基本运算 59
4.1.3 串的存储和基本运算实现 60
4.2 数组 63
4.2.1 数组的逻辑结构 63
4.2.2 数组的内存映像 64
4.2.3 稀疏矩阵 65
4.3 应用举例 69
小结 70
习题 70
第5章 树和二叉树 72
本章要点 72
5.1 树的概念和基本操作 72
5.1.1 树的定义和相关术语 72
5.1.2 树的基本操作 74
5.2 二叉树 75
5.2.1 二叉树的基本概念 75
5.2.2 二叉树的主要性质 76
5.2.3 二叉树的基本操作与存储实现 77
5.2.4 二叉树的遍历 81
5.3.1 树的存储 84
5.3 树和森林 84
5.3.2 树、森林与二叉树的转换 87
5.3.3 树和森林的遍历 89
5.4 最优二叉树——哈夫曼树 91
5.4.1 哈夫曼树的基本概念 91
5.4.2 哈夫曼树的构造算法 92
5.4.3 哈夫曼树在编码问题中的应用 94
5.5 应用举例 96
小结 99
习题 99
6.1 图的基本概念 102
6.1.1 图的定义和术语 102
本章要点 102
第6章 图 102
6.1.2 图的基本操作 106
6.2 图的存储表示 106
6.2.1 邻接矩阵 107
6.2.2 邻接表 109
6.3 图的遍历 111
6.3.1 深度优先搜索 111
6.3.2 广度优先搜索 113
6.4 图的应用 114
6.4.1 最小生成树 114
6.4.2 最短路径 118
6.4.3 拓扑排序 121
6.5 应用举例 125
小结 129
习题 130
本章要点 133
7.1 基本概念和术语 133
第7章 查找 133
7.2 静态查找表 135
7.2.1 静态查找表结构 135
7.2.2 顺序查找 135
7.2.3 有序表的折半查找 136
7.2.4 分块查找 139
7.3 动态查找表 140
7.4 哈希表 144
7.4.1 哈希表和哈希方法 144
7.4.2 常用的哈希函数 145
7.4.3 冲突处理方法 147
7.4.4 哈希表的查找及其分析 149
7.5 应用举例 150
小结 158
习题 158
8.1 基本概念 160
第8章 排序 160
本章要点 160
8.2 简单排序方法 161
8.2.1 直接插入排序 161
8.2.2 冒泡排序 163
8.2.3 简单选择排序 164
8.3 快速排序 165
8.4 堆排序 168
8.5 归并排序 171
8.6 基数排序 173
8.6.1 多关键码排序 173
8.6.2 链式基数排序 174
8.7 排序方法的比较和讨论 176
小结 177
习题 178
参考文献 179