算法导论(原书第3版)
《算法导论(原书第3版)》
基本信息
作者:(美)ThomasH.CormenCharlesE.LeisersonRonaldL.RivestCliffordStein[作译者介绍]
译者:王刚邹恒明殷建平王宏志
出版社:机械工业出版社
ISBN:9787111407010
上架时间:2012-12-6
出版日期:2013年1月
开本:16开
页码:1
版次:1-1
所属分类:计算机>计算机科学理论与基础知识>计算理论>算法
更多关于》》》《算法导论(原书第3版)》
内容简介
书籍
计算机书籍
在有关算法的书中,有一些叙述非常严谨,但不够全面;另一些涉及了大量的题材,但又缺乏严谨性。本书将严谨性和全面性融为一体,深入讨论各类算法,并着力使这些算法的设计和分析能为各个层次的读者接受。全书各章自成体系,可以作为独立的学习单元;算法以英语和伪代码的形式描述,具备初步程序设计经验的人就能看懂;说明和解释力求浅显易懂,不失深度和数学严谨性。《算法导论(原书第3版)》选材经典、内容丰富、结构合理、逻辑清晰,对本科生的数据结构课程和研究生的算法课程都是非常实用的教材,在it专业人员的职业生涯中,本书也是一本案头必备的参考书或工程实践手册。
第3版的主要变化:
新增了vanemdeboas树和多线程算法,并且将矩阵基础移至附录。
修订了递归式(现在称为“分治策略”)那一章的内容,更广泛地覆盖分治法。
移除两章很少讲授的内容:二项堆和排序网络。
修订了动态规划和贪心算法相关内容。
流网络相关材料现在基于边上的全部流。
由于关于矩阵基础和strassen算法的材料移到了其他章,矩阵运算这一章的内容所占篇幅更小。
修改了对knuth-morris-pratt字符串匹配算法的讨论。
新增100道练习和28道思考题,还更新并补充了参考文献。
目录
《算法导论(原书第3版)》
出版者的话
译者序
前言
第一部分 基础知识
第1章 算法在计算中的作用3
1.1 算法3
1.2 作为一种技术的算法6
思考题8
本章注记8
第2章 算法基础9
2.1 插入排序9
2.2 分析算法13
2.3 设计算法16
2.3.1 分治法16
2.3.2 分析分治算法20
思考题22
本章注记24
第3章 函数的增长25
3.1 渐近记号25
3.2 标准记号与常用函数30
思考题35
本章注记36
第4章 分治策略37
4.1 最大子数组问题38
4.2 矩阵乘法的strassen算法43
4.3 用代入法求解递归式47
4.4 用递归树方法求解递归式50
4.5 用主方法求解递归式53
4.6 证明主定理55
4.6.1 对b的幂证明主定理56
4.6.2 向下取整和向上取整58
思考题60
本章注记62
第5章 概率分析和随机算法65
5.1 雇用问题65
5.2 指示器随机变量67
5.3 随机算法69
5.4 概率分析和指示器随机变量的进一步使用73
5.4.1 生日悖论73
5.4.2 球与箱子75
5.4.3 特征序列76
5.4.4 在线雇用问题78
思考题79
本章注记80
第二部分 排序和顺序统计量
第6章 堆排序84
6.1 堆84
6.2 维护堆的性质85
6.3 建堆87
6.4 堆排序算法89
6.5 优先队列90
思考题93
本章注记94
第7章 快速排序95
7.1 快速排序的描述95
7.2 快速排序的性能97
7.3 快速排序的随机化版本100
7.4 快速排序分析101
7.4.1 最坏情况分析101
7.4.2 期望运行时间101
思考题103
本章注记106
第8章 线性时间排序107
8.1 排序算法的下界107
8.2 计数排序108
8.3 基数排序110
8.4 桶排序112
思考题114
本章注记118
第9章 中位数和顺序统计量119
9.1 最小值和最大值119
9.2 期望为线性时间的选择算法120
9.3 最坏情况为线性时间的选择算法123
思考题125
本章注记126
第三部分 数据结构
第10章 基本数据结构129
10.1 栈和队列129
10.2 链表131
10.3 指针和对象的实现134
10.4 有根树的表示137
思考题139
本章注记141
第11章 散列表142
11.1 直接寻址表142
11.2 散列表143
11.3 散列函数147
11.3.1 除法散列法147
11.3.2 乘法散列法148
11.3.3 全域散列法148
11.4 开放寻址法151
11.5 完全散列156
思考题158
本章注记160
第12章 二叉搜索树161
12.1 什么是二叉搜索树161
12.2 查询二叉搜索树163
12.3 插入和删除165
12.4 随机构建二叉搜索树169
思考题171
本章注记173
第13章 红黑树174
13.1 红黑树的性质174
13.2 旋转176
13.3 插入178
13.4 删除183
思考题187
本章注记191
第14章 数据结构的扩张193
14.1 动态顺序统计193
14.2 如何扩张数据结构196
14.3 区间树198
思考题202
本章注记202
第四部分 高级设计和分析技术
第15章 动态规划204
15.1 钢条切割204
15.2 矩阵链乘法210
15.3 动态规划原理215
15.4 最长公共子序列222
15.5 最优二叉搜索树226
思考题231
本章注记236
第16章 贪心算法237
16.1 活动选择问题237
16.2 贪心算法原理242
16.3 赫夫曼编码245
16.4 拟阵和贪心算法250
16.5 用拟阵求解任务调度问题253
思考题255
本章注记257
第17章 摊还分析258
17.1 聚合分析258
17.2 核算法261
17.3 势能法262
17.4 动态表264
17.4.1 表扩张265
17.4.2 表扩张和收缩267
思考题270
本章注记273
第五部分 高级数据结构
第18章 b树277
18.1 b树的定义279
18.2 b树上的基本操作281
18.3 从b树中删除关键字286
思考题288
本章注记289
第19章 斐波那契堆290
19.1 斐波那契堆结构291
19.2 可合并堆操作292
19.3 关键字减值和删除一个结点298
19.4 最大度数的界300
思考题302
本章注记305
第20章 vanemdeboas树306
20.1 基本方法306
20.2 递归结构308
20.2.1 原型vanemdeboas结构310
20.2.2 原型vanemdeboas结构上的操作311
20.3 vanemdeboas树及其操作314
20.3.1 vanemdeboas树315
20.3.2 vanemdeboas树的操作317
思考题322
本章注记323
第21章 用于不相交集合的数据结构324
21.1 不相交集合的操作324
21.2 不相交集合的链表表示326
21.3 不相交集合森林328
*21.4 带路径压缩的按秩合并的分析331
思考题336
本章注记337
第六部分 图算法
第22章 基本的图算法341
22.1 图的表示341
22.2 广度优先搜索343
22.3 深度优先搜索349
22.4 拓扑排序355
22.5 强连通分量357
思考题360
本章注记361
第23章 最小生成树362
23.1 最小生成树的形成362
23.2 kruskal算法和prim算法366
思考题370
本章注记373
第24章 单源最短路径374
24.1 bellmanford算法379
24.2 有向无环图中的单源最短路径问题381
24.3 dijkstra算法383
24.4 差分约束和最短路径387
24.5 最短路径性质的证明391
思考题395
本章注记398
第25章 所有结点对的最短路径问题399
25.1 最短路径和矩阵乘法400
25.2 floydwarshall算法404
25.3 用于稀疏图的johnson算法409
思考题412
本章注记412
第26章 最大流414
26.1 流网络414
26.2 fordfulkerson方法418
26.3 最大二分匹配428
26.4 推送重贴标签算法431
26.5 前置重贴标签算法438
思考题446
本章注记449
第七部分 算法问题选编
第27章 多线程算法453
27.1 动态多线程基础454
27.2 多线程矩阵乘法465
27.3 多线程归并排序468
思考题472
本章注记476
第28章 矩阵运算478
28.1 求解线性方程组478
28.2 矩阵求逆486
28.3 对称正定矩阵和最小二乘逼近489
思考题493
本章注记494
第29章 线性规划495
29.1 标准型和松弛型499
29.2 将问题表达为线性规划504
29.3 单纯形算法507
29.4 对偶性516
29.5 初始基本可行解520
思考题525
本章注记526
第30章 多项式与快速傅里叶变换527
30.1 多项式的表示528
30.2 dft与fft531
30.3 高效fft实现536
思考题539
本章注记541
第31章 数论算法543
31.1 基础数论概念543
31.2 最大公约数547
31.3 模运算550
31.4 求解模线性方程554
31.5 中国余数定理556
31.6 元素的幂558
31.7 rsa公钥加密系统561
31.8 素数的测试565
31.9 整数的因子分解571
思考题574
本章注记576
第32章 字符串匹配577
32.1 朴素字符串匹配算法578
32.2 rabinkarp算法580
32.3 利用有限自动机进行字符串匹配583
32.4 knuthmorrispratt算法588
思考题594
本章注记594
第33章 计算几何学595
33.1 线段的性质595
33.2 确定任意一对线段是否相交599
33.3 寻找凸包604
33.4 寻找最近点对610
思考题613
本章注记615
第34章 np完全性616
34.1 多项式时间619
34.2 多项式时间的验证623
34.3 np完全性与可归约性626
34.4 np完全性的证明633
34.5 np完全问题638
34.5.1 团问题638
34.5.2 顶点覆盖问题640
34.5.3 哈密顿回路问题641
34.5.4 旅行商问题644
34.5.5 子集和问题645
思考题647
本章注记649
第35章 近似算法651
35.1 顶点覆盖问题652
35.2 旅行商问题654
35.2.1 满足三角不等式的旅行商问题654
35.2.2 一般旅行商问题656
35.3 集合覆盖问题658
35.4 随机化和线性规划661
35.5 子集和问题663
思考题667
本章注记669
第八部分 附录:数学基础知识
附录a 求和672
a.1 求和公式及其性质672
a.2 确定求和时间的界674
思考题678
附录注记678
附录b 集合等离散数学内容679
b.1 集合679
b.2 关系682
b.3 函数683
b.4 图685
b.5 树687
b.5.1 自由树688
b.5.2 有根树和有序树689
b.5.3 二叉树和位置树690
思考题691
附录注记692
附录c 计数与概率693
c.1 计数693
c.2 概率696
c.3 离散随机变量700
c.4 几何分布与二项分布702
*c.5 二项分布的尾部705
思考题708
附录注记708
附录d 矩阵709
d.1 矩阵与矩阵运算709
d.2 矩阵基本性质712
思考题714
附录注记715
参考文献716
索引732