《实用数据结构教程 Java语言描述》PDF下载

  • 购买积分:10 如何计算积分?
  • 作  者:周大庆编著
  • 出 版 社:北京市:人民邮电出版社
  • 出版年份:2007
  • ISBN:7115159076
  • 页数:233 页
图书介绍:本书以新型面向对象的Java语言作为描述语言,系统介绍了如何用面向对象的方法来设计和实现传统的数据结构,内容包括数组、链表、栈、队列、表、二叉树、优先队列、堆、集合、映射、散列表、树和图等基本数据结构,以及插入、删除、遍历、查找、归并和排序等基本算法。本书突出了抽象数据类型的概念,提供了大量精心设计的示例程序,不仅讲述了常用数据结构的具体实现,而且抽象出一般的设计原则。本书选材精当、结构新颖、深入浅出、叙述简明,可作为高等院校计算机专业和相近专业的教材或参考书,也可供从事计算机应用的工程技术人员参考。

第1章 绪论 1

1.1 数据结构与数据类型 1

1.2 抽象数据类型 3

1.2.1 ADT的规格说明 4

1.2.2 ADT的实现 4

1.2.3 Java中ADT的规格说明与实现 4

1.3 串抽象数据类型 7

1.3.1 串ADT的规格说明 7

1.3.2 串ADT的实现 7

习题 9

第2章 算法 11

2.1 问题、算法和程序 11

2.2 算法的代价 12

2.3 算法分析 13

2.3.1 规模与基本操作 13

2.3.2 运行时间和增长率 13

2.3.3 最佳、最差和平均情况 15

2.4 大O符号 16

2.4.1 大O的定义 16

2.4.2 大O的性质 17

2.4.3 大O的计算 17

2.5 空间代价 19

2.6 递归算法 20

习题 24

第3章 数组 25

3.1 数组 25

3.1.1 子数组 27

3.1.2 有序数组 27

3.1.3 二维数组 28

3.2 插入 29

3.3 删除 30

3.4 查找 31

3.4.1 线性查找 31

3.4.2 二分查找 33

3.4.3 查找算法比较 35

3.5 归并 35

3.6 排序 37

3.6.1 冒泡排序 37

3.6.2 选择排序 39

3.6.3 插入排序 41

3.6.4 归并排序 42

3.6.5 快速排序 44

3.6.6 排序算法比较 47

习题 48

第4章 链表 50

4.1 链表 50

4.1.1 单向链表 51

4.1.2 双向链表 53

4.1.3 有序链表 56

4.1.4 循环链表 56

4.2 插入 56

4.2.1 单向链表插入 56

4.2.2 双向链表插入 58

4.3 删除 59

4.3.1 单向链表删除 60

4.3.2 双向链表删除 60

4.4 查找 62

习题 62

第5章 栈与队列 65

5.1 栈 65

5.1.1 栈的概念 65

5.1.2 栈的应用 66

5.1.3 栈ADT的规格说明 66

5.1.4 用数组实现栈 67

5.1.5 用单向链表实现栈 70

5.2 队列 72

5.2.1 队列的概念 72

5.2.2 队列的应用 72

5.2.3 队列ADT的规格说明 73

5.2.4 用数组实现队列 73

5.2.5 用单向链表实现队列 77

5.2.6 基数排序 79

习题 81

第6章 表 82

6.1 表的概念 82

6.2 表的应用 83

6.3 表ADT的规格说明 83

6.4 用数组实现表 84

6.5 用单向链表实现表 86

习题 88

第7章 二叉树 90

7.1 二叉树 90

7.1.1 二叉树的概念 90

7.1.2 满二叉树 92

7.1.3 平衡二叉树 93

7.1.4 二叉树结点类 94

7.2 二叉树的遍历 95

7.3 二叉查找树 97

7.3.1 二叉查找树的概念 97

7.3.2 查找 99

7.3.3 插入 101

7.3.4 删除 103

7.4 二叉查找树的平衡化重构 108

7.5 将二叉查找树保存到文件 109

7.5.1 使用前序遍历把二叉查找树保存到文件 110

7.5.2 使用中序遍历把二叉查找树保存到文件 111

习题 112

第8章 优先队列与堆 114

8.1 优先队列的概念 114

8.2 优先队列的应用 114

8.3 优先队列ADT的规格说明 115

8.4 优先队列的实现 115

8.5 完全二叉树与堆 116

8.5.1 完全二叉树 116

8.5.2 堆 117

8.6 用堆实现优先队列 119

8.7 堆排序 122

8.8 赫夫曼编码树 122

8.8.1 建立赫夫曼编码树 123

8.8.2 赫夫曼编码及其用法 127

习题 130

第9章 集合与映射 131

9.1 集合 131

9.1.1 集合的概念 131

9.1.2 集合的应用 132

9.1.3 集合ADT的规格说明 133

9.1.4 集合的实现 134

9.2 映射 147

9.2.1 映射的概念 147

9.2.2 映射的应用 147

9.2.3 映射ADT的规格说明 148

9.2.4 映射的实现 148

习题 154

第10章 散列表 156

10.1 散列表原理 156

10.2 闭桶散列表 158

10.2.1 插入 160

10.2.2 查找 160

10.2.3 删除 161

10.2.4 分析 161

10.2.5 设计 161

10.2.6 再散列 162

10.3 开桶散列表 163

10.3.1 插入 165

10.3.2 查找 167

10.3.3 删除 168

10.3.4 分析 169

10.3.5 设计 169

10.3.6 双散列 170

10.4 用散列表实现集合与映射 172

习题 173

第11章 树 174

11.1 树的概念 174

11.2 树的应用 175

11.3 左子结点/右兄弟结点表示法 176

11.4 树的遍历 180

11.5 父指针表示法 181

11.6 UNION/FIND算法与等价类问题 182

习题 186

第12章 图 187

12.1 图的概念 187

12.2 图的应用 189

12.3 图ADT的规格说明 190

12.4 图的实现 191

12.4.1 用邻接矩阵实现图 191

12.4.2 用邻接表实现图 193

12.5 图的遍历 195

12.5.1 深度优先搜索 195

12.5.2 广度优先搜索 197

12.6 拓扑排序 198

12.6.1 基于递归的拓扑排序算法 198

12.6.2 基于队列的拓扑排序算法 199

12.7 最短路径问题 200

12.7.1 单源最短路径 201

12.7.2 每对顶点间的最短路径 204

12.8 最小生成树 205

12.8.1 Prim算法 205

12.8.2 Kruskal算法 207

12.9 迷宫的生成和求解 209

12.9.1 迷宫的表示 210

12.9.2 用DFS算法生成迷宫 212

12.9.3 用Prim算法生成迷宫 213

12.9.4 用Kruskal算法生成迷宫 215

12.9.5 迷宫求解算法 216

习题 217

附录A 数学预备知识 218

附录B Java语言概要 224

附录C 课程实验 230

参考文献 233