作者:
韦斯 (Mark Allen Weiss)
出版社: 机械工业出版社
副标题: Java语言描述
原作名: Data Structures and Algorithm Analysis in Java Third Edition
译者: 陈越
出版年: 2016-3-1
页数: 403
定价: 69.00元
装帧: 平装
丛书: 计算机科学丛书
ISBN: 9787111528395
出版社: 机械工业出版社
副标题: Java语言描述
原作名: Data Structures and Algorithm Analysis in Java Third Edition
译者: 陈越
出版年: 2016-3-1
页数: 403
定价: 69.00元
装帧: 平装
丛书: 计算机科学丛书
ISBN: 9787111528395
内容简介 · · · · · ·
本书是国外数据结构与算法分析方面的经典教材,使用卓越的Java编程语言作为实现工具讨论了数据结构(组织大量数据的方法)和算法分析(对算法运行时间的估计)。本书把算法分析与有效率的Java程序的开发有机地结合起来,深入分析每种算法,内容全面、缜密严格,并细致讲解精心构造程序的方法。
数据结构与算法分析的创作者
· · · · · ·
作者简介 · · · · · ·
马克·艾伦·维斯(MarkAllenWeiss)佛罗里达国际大学计算与信息科学学院教授、副院长,本科教育主任和研究生教育主任。他于1987年获得普林斯顿大学计算机科学博士学位,师从BobSedgewick。他曾经担任全美AP(AdvancedPlacement)考试计算机学科委员会的主席(2000-2004)。他的主要研究兴趣是数据结构、算法和教育学。
目录 · · · · · ·
出版者的话
前言
第1章 引论1
1.1 本书讨论的内容1
1.2 数学知识复习2
1.2.1 指数2
1.2.2 对数2
1.2.3 级数2
1.2.4 模运算4
1.2.5 证明的方法4
1.3 递归简论5
1.4 实现泛型构件pre-Java 57
1.4.1 使用Object表示泛型8
1.4.2 基本类型的包装9
1.4.3 使用接口类型表示泛型9
1.4.4 数组类型的兼容性10
1.5 利用Java 5泛型特性实现泛型构件11
1.5.1 简单的泛型类和接口11
1.5.2 自动装箱/拆箱11
1.5.3 菱形运算符12
1.5.4 带有限制的通配符12
1.5.5 泛型static方法14
1.5.6 类型限界14
1.5.7 类型擦除15
1.5.8 对于泛型的限制15
1.6 函数对象16
小结18
练习18
参考文献19
第2章 算法分析20
2.1 数学基础20
2.2 模型22
2.3 要分析的问题22
2.4 运行时间计算24
2.4.1 一个简单的例子24
2.4.2 一般法则24
2.4.3 最大子序列和问题的求解26
2.4.4 运行时间中的对数31
2.4.5 分析结果的准确性33
小结33
练习34
参考文献37
第3章 表、栈和队列39
3.1 抽象数据类型39
3.2 表ADT39
3.2.1 表的简单数组实现40
3.2.2 简单链表40
3.3 Java Collections API中的表41
3.3.1 Collection接口41
3.3.2 Iterator接口42
3.3.3 List接口、ArrayList类和LinkedList类43
3.3.4 例子:remove方法对LinkedList类的使用44
3.3.5 关于ListIterator接口46
3.4 ArrayList类的实现46
3.4.1 基本类46
3.4.2 迭代器、Java嵌套类和内部类49
3.5 LinkedList类的实现52
3.6 栈ADT58
3.6.1 栈模型58
3.6.2 栈的实现59
3.6.3 应用59
3.7 队列ADT65
3.7.1 队列模型65
3.7.2 队列的数组实现65
3.7.3 队列的应用66
小结67
练习67
第4章 树71
4.1 预备知识71
4.1.1 树的实现72
4.1.2 树的遍历及应用72
4.2 二叉树75
4.2.1 实现76
4.2.2 例子:表达式树76
4.3 查找树ADT——二叉查找树78
4.3.1 contains方法79
4.3.2 findMin方法和findMax方法80
4.3.3 insert方法80
4.3.4 remove方法82
4.3.5 平均情况分析83
4.4 AVL树86
4.4.1 单旋转87
4.4.2 双旋转89
4.5 伸展树94
4.5.1 一个简单的想法(不能直接使用)95
4.5.2 展开96
4.6 再探树的遍历100
4.7 B树101
4.8 标准库中的集合与映射105
4.8.1 关于Set接口105
4.8.2 关于Map接口105
4.8.3 TreeSet类和TreeMap类的实现106
4.8.4 使用多个映射的实例106
小结111
练习111
参考文献115
第5章 散列117
5.1 一般想法117
5.2 散列函数117
5.3 分离链接法119
5.4 不用链表的散列表123
5.4.1 线性探测法123
5.4.2 平方探测法124
5.4.3 双散列129
5.5 再散列130
5.6 标准库中的散列表132
5.7 最坏情形下O(1)访问的散列表 133
5.7.1 完美散列133
5.7.2 布谷鸟散列135
5.7.3 跳房子散列143
5.8 通用散列法146
5.9 可扩散列148
小结149
练习150
参考文献153
第6章 优先队列(堆)156
6.1 模型156
6.2 一些简单的实现156
6.3 二叉堆157
6.3.1 结构性质157
6.3.2 堆序性质157
6.3.3 基本的堆操作158
6.3.4 其他的堆操作162
6.4 优先队列的应用164
6.4.1 选择问题164
6.4.2 事件模拟165
6.5 d-堆166
6.6 左式堆167
6.6.1 左式堆性质167
6.6.2 左式堆操作168
6.7 斜堆172
6.8 二项队列173
6.8.1 二项队列结构174
6.8.2 二项队列操作174
6.8.3 二项队列的实现176
6.9 标准库中的优先队列180
小结180
练习181
参考文献184
第7章 排序186
7.1 预备知识186
7.2 插入排序186
7.2.1 算法186
7.2.2 插入排序的分析187
7.3 一些简单排序算法的下界187
7.4 希尔排序188
7.5 堆排序191
7.6 归并排序193
7.7 快速排序198
7.7.1 选取枢纽元199
7.7.2 分割策略200
7.7.3 小数组202
7.7.4 实际的快速排序例程202
7.7.5 快速排序的分析203
7.7.6 选择问题的线性期望时间算法206
7.8 排序算法的一般下界207
7.9 选择问题的决策树下界209
7.10 对手下界210
7.11 线性时间的排序:桶排序和基数排序212
7.12 外部排序216
7.12.1 为什么需要一些新的算法217
7.12.2 外部排序模型217
7.12.3 简单算法217
7.12.4 多路合并218
7.12.5 多相合并219
7.12.6 替换选择219
小结220
练习221
参考文献225
第8章 不相交集类227
8.1 等价关系227
8.2 动态等价性问题227
8.3 基本数据结构229
8.4 灵巧求并算法231
8.5 路径压缩233
8.6 路径压缩和按秩求并的最坏情形234
8.6.1 缓慢增长的函数235
8.6.2 利用递归分解的分析235
8.6.3 O(M log*N)界240
8.6.4 O(Mα(M,N))界240
8.7 一个应用241
小结243
练习243
参考文献244
第9章 图论算法246
9.1 若干定义246
9.2 拓扑排序248
9.3 最短路径算法250
9.3.1 无权最短路径251
9.3.2 Dijkstra算法254
9.3.3 具有负边值的图258
9.3.4 无圈图259
9.3.5 所有点对最短路径261
9.3.6 最短路径的例子261
9.4 网络流问题262
9.5 最小生成树267
9.5.1 Prim算法267
9.5.2 Kruskal算法269
9.6 深度优先搜索的应用270
9.6.1 无向图270
9.6.2 双连通性271
9.6.3 欧拉回路273
9.6.4 有向图275
9.6.5 查找强分支276
9.7 NP-完全性介绍277
9.7.1 难与易278
9.7.2 NP类278
9.7.3 NP-完全问题279
小结280
练习280
参考文献284
第10章 算法设计技巧288
10.1 贪婪算法288
10.1.1 一个简单的调度问题288
10.1.2 哈夫曼编码290
10.1.3 近似装箱问题293
10.2 分治算法298
10.2.1 分治算法的运行时间298
10.2.2 最近点问题300
10.2.3 选择问题302
10.2.4 一些算术问题的理论改进304
10.3 动态规划307
10.3.1 用一个表代替递归307
10.3.2 矩阵乘法的顺序安排309
10.3.3 最优二叉查找树311
10.3.4 所有点对最短路径312
10.4 随机化算法314
10.4.1 随机数发生器315
10.4.2 跳跃表319
10.4.3 素性测试320
10.5 回溯算法322
10.5.1 收费公路重建问题323
10.5.2 博弈326
小结331
练习331
参考文献336
第11章 摊还分析340
11.1 一个无关的智力问题340
11.2 二项队列340
11.3 斜堆344
11.4 斐波那契堆345
11.4.1 切除左式堆中的节点346
11.4.2 二项队列的懒惰合并347
11.4.3 斐波那契堆操作349
11.4.4 时间界的证明350
11.5 伸展树351
小结354
练习354
参考文献355
第12章 高级数据结构及其实现356
12.1 自顶向下伸展树356
12.2 红黑树362
12.2.1 自底向上的插入362
12.2.2 自顶向下红黑树363
12.2.3 自顶向下的删除367
12.3 treap树368
12.4 后缀数组与后缀树370
12.4.1 后缀数组371
12.4.2 后缀树373
12.4.3 线性时间的后缀数组和后缀树的构建375
12.5 k-d树385
12.6 配对堆387
小结392
练习393
参考文献396
索引399
· · · · · · (收起)
前言
第1章 引论1
1.1 本书讨论的内容1
1.2 数学知识复习2
1.2.1 指数2
1.2.2 对数2
1.2.3 级数2
1.2.4 模运算4
1.2.5 证明的方法4
1.3 递归简论5
1.4 实现泛型构件pre-Java 57
1.4.1 使用Object表示泛型8
1.4.2 基本类型的包装9
1.4.3 使用接口类型表示泛型9
1.4.4 数组类型的兼容性10
1.5 利用Java 5泛型特性实现泛型构件11
1.5.1 简单的泛型类和接口11
1.5.2 自动装箱/拆箱11
1.5.3 菱形运算符12
1.5.4 带有限制的通配符12
1.5.5 泛型static方法14
1.5.6 类型限界14
1.5.7 类型擦除15
1.5.8 对于泛型的限制15
1.6 函数对象16
小结18
练习18
参考文献19
第2章 算法分析20
2.1 数学基础20
2.2 模型22
2.3 要分析的问题22
2.4 运行时间计算24
2.4.1 一个简单的例子24
2.4.2 一般法则24
2.4.3 最大子序列和问题的求解26
2.4.4 运行时间中的对数31
2.4.5 分析结果的准确性33
小结33
练习34
参考文献37
第3章 表、栈和队列39
3.1 抽象数据类型39
3.2 表ADT39
3.2.1 表的简单数组实现40
3.2.2 简单链表40
3.3 Java Collections API中的表41
3.3.1 Collection接口41
3.3.2 Iterator接口42
3.3.3 List接口、ArrayList类和LinkedList类43
3.3.4 例子:remove方法对LinkedList类的使用44
3.3.5 关于ListIterator接口46
3.4 ArrayList类的实现46
3.4.1 基本类46
3.4.2 迭代器、Java嵌套类和内部类49
3.5 LinkedList类的实现52
3.6 栈ADT58
3.6.1 栈模型58
3.6.2 栈的实现59
3.6.3 应用59
3.7 队列ADT65
3.7.1 队列模型65
3.7.2 队列的数组实现65
3.7.3 队列的应用66
小结67
练习67
第4章 树71
4.1 预备知识71
4.1.1 树的实现72
4.1.2 树的遍历及应用72
4.2 二叉树75
4.2.1 实现76
4.2.2 例子:表达式树76
4.3 查找树ADT——二叉查找树78
4.3.1 contains方法79
4.3.2 findMin方法和findMax方法80
4.3.3 insert方法80
4.3.4 remove方法82
4.3.5 平均情况分析83
4.4 AVL树86
4.4.1 单旋转87
4.4.2 双旋转89
4.5 伸展树94
4.5.1 一个简单的想法(不能直接使用)95
4.5.2 展开96
4.6 再探树的遍历100
4.7 B树101
4.8 标准库中的集合与映射105
4.8.1 关于Set接口105
4.8.2 关于Map接口105
4.8.3 TreeSet类和TreeMap类的实现106
4.8.4 使用多个映射的实例106
小结111
练习111
参考文献115
第5章 散列117
5.1 一般想法117
5.2 散列函数117
5.3 分离链接法119
5.4 不用链表的散列表123
5.4.1 线性探测法123
5.4.2 平方探测法124
5.4.3 双散列129
5.5 再散列130
5.6 标准库中的散列表132
5.7 最坏情形下O(1)访问的散列表 133
5.7.1 完美散列133
5.7.2 布谷鸟散列135
5.7.3 跳房子散列143
5.8 通用散列法146
5.9 可扩散列148
小结149
练习150
参考文献153
第6章 优先队列(堆)156
6.1 模型156
6.2 一些简单的实现156
6.3 二叉堆157
6.3.1 结构性质157
6.3.2 堆序性质157
6.3.3 基本的堆操作158
6.3.4 其他的堆操作162
6.4 优先队列的应用164
6.4.1 选择问题164
6.4.2 事件模拟165
6.5 d-堆166
6.6 左式堆167
6.6.1 左式堆性质167
6.6.2 左式堆操作168
6.7 斜堆172
6.8 二项队列173
6.8.1 二项队列结构174
6.8.2 二项队列操作174
6.8.3 二项队列的实现176
6.9 标准库中的优先队列180
小结180
练习181
参考文献184
第7章 排序186
7.1 预备知识186
7.2 插入排序186
7.2.1 算法186
7.2.2 插入排序的分析187
7.3 一些简单排序算法的下界187
7.4 希尔排序188
7.5 堆排序191
7.6 归并排序193
7.7 快速排序198
7.7.1 选取枢纽元199
7.7.2 分割策略200
7.7.3 小数组202
7.7.4 实际的快速排序例程202
7.7.5 快速排序的分析203
7.7.6 选择问题的线性期望时间算法206
7.8 排序算法的一般下界207
7.9 选择问题的决策树下界209
7.10 对手下界210
7.11 线性时间的排序:桶排序和基数排序212
7.12 外部排序216
7.12.1 为什么需要一些新的算法217
7.12.2 外部排序模型217
7.12.3 简单算法217
7.12.4 多路合并218
7.12.5 多相合并219
7.12.6 替换选择219
小结220
练习221
参考文献225
第8章 不相交集类227
8.1 等价关系227
8.2 动态等价性问题227
8.3 基本数据结构229
8.4 灵巧求并算法231
8.5 路径压缩233
8.6 路径压缩和按秩求并的最坏情形234
8.6.1 缓慢增长的函数235
8.6.2 利用递归分解的分析235
8.6.3 O(M log*N)界240
8.6.4 O(Mα(M,N))界240
8.7 一个应用241
小结243
练习243
参考文献244
第9章 图论算法246
9.1 若干定义246
9.2 拓扑排序248
9.3 最短路径算法250
9.3.1 无权最短路径251
9.3.2 Dijkstra算法254
9.3.3 具有负边值的图258
9.3.4 无圈图259
9.3.5 所有点对最短路径261
9.3.6 最短路径的例子261
9.4 网络流问题262
9.5 最小生成树267
9.5.1 Prim算法267
9.5.2 Kruskal算法269
9.6 深度优先搜索的应用270
9.6.1 无向图270
9.6.2 双连通性271
9.6.3 欧拉回路273
9.6.4 有向图275
9.6.5 查找强分支276
9.7 NP-完全性介绍277
9.7.1 难与易278
9.7.2 NP类278
9.7.3 NP-完全问题279
小结280
练习280
参考文献284
第10章 算法设计技巧288
10.1 贪婪算法288
10.1.1 一个简单的调度问题288
10.1.2 哈夫曼编码290
10.1.3 近似装箱问题293
10.2 分治算法298
10.2.1 分治算法的运行时间298
10.2.2 最近点问题300
10.2.3 选择问题302
10.2.4 一些算术问题的理论改进304
10.3 动态规划307
10.3.1 用一个表代替递归307
10.3.2 矩阵乘法的顺序安排309
10.3.3 最优二叉查找树311
10.3.4 所有点对最短路径312
10.4 随机化算法314
10.4.1 随机数发生器315
10.4.2 跳跃表319
10.4.3 素性测试320
10.5 回溯算法322
10.5.1 收费公路重建问题323
10.5.2 博弈326
小结331
练习331
参考文献336
第11章 摊还分析340
11.1 一个无关的智力问题340
11.2 二项队列340
11.3 斜堆344
11.4 斐波那契堆345
11.4.1 切除左式堆中的节点346
11.4.2 二项队列的懒惰合并347
11.4.3 斐波那契堆操作349
11.4.4 时间界的证明350
11.5 伸展树351
小结354
练习354
参考文献355
第12章 高级数据结构及其实现356
12.1 自顶向下伸展树356
12.2 红黑树362
12.2.1 自底向上的插入362
12.2.2 自顶向下红黑树363
12.2.3 自顶向下的删除367
12.3 treap树368
12.4 后缀数组与后缀树370
12.4.1 后缀数组371
12.4.2 后缀树373
12.4.3 线性时间的后缀数组和后缀树的构建375
12.5 k-d树385
12.6 配对堆387
小结392
练习393
参考文献396
索引399
· · · · · · (收起)
丛书信息
· · · · · ·
计算机科学丛书(共619册),
这套丛书还有
《计算机组成与设计:硬件/软件接口 RISC-V版(原书第2版)》《程序设计语言的形式语义》《社会计算》《C程序设计语言》《系统分析与设计方法》
等
。
喜欢读"数据结构与算法分析"的人也喜欢 · · · · · ·
数据结构与算法分析的书评 · · · · · · ( 全部 50 条 )
优选 C 语言描述的算法分析 + 不用心的翻译
本书作者 Mark Allen Weiss 还写过 C 语言描述 和 Java 语言描述 版本的数据结构和算法分析教程。 另外,图灵出版社的同系列还有 Michael McMillan 写的 C# 语言描述 版本的算法书。 C++ 熟练者可忽略讲述 C++ 特性的第1章,如果把这些关于 C++ 特性的篇幅去掉,本书会精...
(展开)
最好的数据结构与算法分析入门教程
因为最近需要复习数据结构与算法,所以网上搜索了下这方面的经典书籍。这本书的C语言版本高居榜首,获得一致好评,正好该书又有Java语言的版本,就买来拜读一下。前后大概花了1个月的时间将该书看了两遍,书中的主要数据结构都敲代码实现了一遍,现在算是将以前的数据结构课程...
(展开)
> 更多书评 50篇
论坛 · · · · · ·
在这本书的论坛里发言这本书的其他版本 · · · · · · ( 全部27 )
-
机械工业出版社 (2004)9.0分 2155人读过
-
Addison Wesley (1996)8.7分 72人读过
-
人民邮电出版社 (2007)8.5分 325人读过
-
机械工业出版社 (2009)8.5分 295人读过
以下书单推荐 · · · · · · ( 全部 )
- 计算机专业 (乱翻词典)
- 算法 (whg)
- T (dhcn)
- Java数据结构 (梦)
- 引进西方教科书 Pearson篇 (已己巳)
谁读这本书? · · · · · ·
二手市场
· · · · · ·
- 在豆瓣转让 有386人想读,手里有一本闲着?
订阅关于数据结构与算法分析的评论:
feed: rss 2.0
2 有用 帝都企鹅 2018-11-07 11:05:56
书是好书,内容没问题,但是翻译真的有点烂,专业术语都能翻译错,很难想象到底是不是业内人士翻译的。 最好对照英文看,专有名词翻译过来的莫名其妙
0 有用 zifangsky 2020-05-06 20:43:34
这本书难度挺高的,然后翻译方面也有点拗口,不过总体来看还不错吧。
0 有用 奥特快 2019-12-26 16:06:12
啃了一周,啃完了前九章。真的不是给新手写的,把读书笔记写完回头在啃后三章。
3 有用 大概 2016-11-04 10:42:41
不太适合入门,之前跟过CS61B的课,再看这本书前300页还算理解的充分,后面高级数据结构就懵逼了。书内多数证明都很有意思很翔实,不懂得地方以后学习过程中再做研究。翻译稍微有点生硬的感觉,也有可能是术语太多造成的正常体验。
0 有用 lazy_mo 2022-03-05 17:28:41
周末翻了翻手里的这版(2004)想找些定义,发现翻译的是真烂…
0 有用 西西弗 2023-06-03 18:40:58 北京
我还是刷点通俗易懂的吧,这个太难啃了
0 有用 Luzhuo 2023-03-16 02:38:20 浙江
还可以,内容不算全,但是好理解,是最新版
1 有用 ICE CHAN 2022-09-22 12:37:32 福建
读本科的时候看了一遍中文版,结果读Master又认真读了一遍英文版。
1 有用 大虾萌 2022-06-17 14:40:50
I hate this book. 这本书的英文其实就很蹩脚,中文版的翻译可能加深了对读者的荼毒。 这本书有很多缺点:他就不想把东西给你解释明白,随便说一个定理,然后后面引出的结论就说是前面东西很清楚的证明了,没有任何中间思维过程,what??;有的时候又会莫名的啰嗦,比如前后两段,都说一次“我们把这个集合叫做R”之类的;有时候像是概述类论文,就楞给个公式,然后提两句相关内容;cross refe... I hate this book. 这本书的英文其实就很蹩脚,中文版的翻译可能加深了对读者的荼毒。 这本书有很多缺点:他就不想把东西给你解释明白,随便说一个定理,然后后面引出的结论就说是前面东西很清楚的证明了,没有任何中间思维过程,what??;有的时候又会莫名的啰嗦,比如前后两段,都说一次“我们把这个集合叫做R”之类的;有时候像是概述类论文,就楞给个公式,然后提两句相关内容;cross reference就是一坨shit,对其他章节的引述太随意,通常你不知道他在引用什么;对递归有一种谜一样的偏见;code不完全,让你online去看;排版相当糟糕,code和对应的解释通常不在一页上,得跳来跳去的翻页,看过stevens的unix系列,这个编辑只能负分。 看这本书真是煎熬,烂书。 (展开)
1 有用 没有色彩的 2022-05-15 20:06:44
大学的时候好好磕一顿,也不至于现在这样