购买云解压PDF图书

当前位置: 实用数据结构教程 Java语言描述 > 购买云解压PDF图书
实用数据结构教程 Java语言描述
  • 作 者:周大庆编著
  • 出 版 社:北京市:人民邮电出版社
  • 出版年份:2007
  • ISBN:7115159076
  • 注意:在使用云解压之前,请认真核对实际PDF页数与内容!

在线云解压

价格(点数)

购买连接

说明

转为PDF格式

9

立即购买

(在线云解压服务)

云解压服务说明

1、本站所有的云解压默认都是转为PDF格式,该格式图书只能阅读和打印,不能再次编辑。

云解压下载及付费说明

1、所有的电子图书云解压均转换为PDF格式,支持电脑、手机、平板等各类电子设备阅读;可以任意拷贝文件到不同的阅读设备里进行阅读。

2、云解压在提交订单后一般半小时内处理完成,最晚48小时内处理完成。(非工作日购买会延迟)

第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

购买PDF格式(9分)
返回顶部