《算法设计与应用》PDF下载

  • 购买积分:16 如何计算积分?
  • 作  者:(美)迈克尔·T.古德里奇,罗伯托·塔马西亚著;乔海燕,李悫炜,王烁程译
  • 出 版 社:北京:机械工业出版社
  • 出版年份:2018
  • ISBN:9787111582779
  • 页数:510 页
图书介绍:本书全面系统地介绍算法设计和算法应用的各个领域,内容涵盖经典数据结构、经典算法、算法分析方法、算法设计方法以及算法在各个领域的应用,还包含一些高级主题。本书采用应用驱动的方法引入各章内容,内容编排清晰合理,讲解由浅入深。此外,各章都附有巩固练习、创新练习和应用练习三种类型的题目,为读者理解和掌握算法设计和应用提供了很好的素材。

第1章 算法分析 1

1.1分析算法 2

1.1.1伪代码 2

1.1.2随机存取机模型 4

1.1.3基本操作数目的计算 4

1.1.4递归算法的分析 6

1.1.5渐近表示法 6

1.1.6渐近表示法的重要性 10

1.2相关数学知识复习 11

1.2.1求和 11

1.2.2对数和幂 12

1.2.3简单的证明技术 13

1.2.4概率基础 16

1.3算法分析案例 18

1.3.1最大子数组问题的第一个解 18

1.3.2一种改进的求最大子数组算法 19

1.3.3线性时间的最大子数组算法 20

1.4平摊分析 21

1.4.1平摊技术 22

1.4.2对一个可扩展数组实现的分析 24

1.5练习 26

本章注记 31

第一部分 数据结构 34

第2章 基本数据结构 34

2.1栈和队列 35

2.1.1栈 35

2.1.2队列 37

2.2列表 38

2.2.1基于索引的列表 39

2.2.2链表 40

2.3树 44

2.3.1树的定义 45

2.3.2树的遍历 46

2.3.3二叉树 49

2.3.4表示树的数据结构 53

2.4练习 55

本章注记 58

第3章 二叉搜索树 59

3.1搜索和更新 60

3.1.1二叉搜索树的定义 62

3.1.2二叉搜索树中的搜索 62

3.1.3二叉搜索树中的插入 64

3.1.4二叉搜索树中的删除 64

3.1.5二叉搜索树的性能 65

3.2范围查询 66

3.3基于索引的搜索 68

3.4随机构造二叉搜索树 70

3.5练习 72

本章注记 75

第4章 平衡二叉搜索树 76

4.1秩和旋转 77

4.2 AVL树 79

4.3红黑树 82

4.4弱AVL树 85

4.5伸展树 91

4.6练习 97

本章注记 101

第5章 优先队列和堆 102

5.1优先队列 103

5.2 PQ排序、选择排序和插入排序 103

5.2.1选择排序 104

5.2.2插入排序 106

5.3堆 107

5.3.1基于数组结构的二叉树 109

5.3.2堆中的插入 110

5.3.3堆中的删除 112

5.4堆排序 114

5.5扩展优先队列 118

5.6练习 119

本章注记 122

第6章 散列表 123

6.1映射 124

6.1.1映射的定义 124

6.1.2查找表 125

6.2散列函数 126

6.2.1分量求和 127

6.2.2多项式求值函数 127

6.2.3基于表格的散列 128

6.2.4取模 128

6.2.5随机线性和多项式函数 129

6.3碰撞处理与再散列 129

6.3.1拉链法 129

6.3.2开放寻址法 130

6.3.3线性探测 131

6.3.4平方探测 133

6.3.5双重散列 133

6.3.6再散列 134

6.4布谷鸟散列 134

6.5通用散列 138

6.6练习 140

本章注记 142

第7章 并查集结构 143

7.1并查集及其应用 144

7.1.1连通分支 144

7.1.2迷宫建筑和渗透理论 145

7.2基于列表的实现 146

7.3基于树的实现 148

7.4练习 153

本章注记 155

第二部分 排序和选择 158

第8章 归并排序和快速排序 158

8.1归并排序 159

8.1.1分而治之 159

8.1.2归并排序和递推方程 162

8.2快速排序 163

8.2.1随机快速排序 165

8.2.2原地快速排序 166

8.3基于比较的排序的下界 168

8.4练习 169

本章注记 172

第9章 快速排序和选择 173

9.1桶排序和基数排序 174

9.1.1桶排序 174

9.1.2基数排序 175

9.2选择 176

9.2.1随机快速选择 176

9.2.2确定性选择 178

9.3加权中位数 179

9.4练习 181

本章注记 183

第三部分 基本技术 186

第10章 贪心法 186

10.1分份背包问题 187

10.2任务调度 189

10.3文本压缩和哈夫曼编码 191

10.4练习 195

本章注记 197

第11章 分治法 198

11.1递推与主定理 199

11.2整数乘法 203

11.3矩阵乘法 204

11.4极大点集问题 205

11.5练习 206

本章注记 209

第12章 动态规划 210

12.1矩阵连乘 211

12.2通用技术 213

12.3望远镜调度 213

12.4博弈策略 216

12.4.1硬币行 216

12.4.2概率博弈策略与逆向归纳法 217

12.5最长公共子序列问题 219

12.5.1问题定义 219

12.5.2应用动态规划解LCS问题 219

12.6 0-1背包问题 221

12.7练习 223

本章注记 227

第13章 图及遍历 228

13.1图的术语和表示方法 228

13.1.1图的一些术语 229

13.1.2图的操作 231

13.1.3表示图的数据结构 232

13.2深度优先搜索 235

13.3广度优先搜索 237

13.4有向图 239

13.4.1遍历有向图 240

13.4.2传递闭包 242

13.4.3有向DFS和垃圾回收 244

13.4.4有向无环图 246

13.5双连通分量 249

13.6练习 252

本章注记 255

第四部分 图算法 258

第14章 最短路径 258

14.1单源最短路径 258

14.2 Dijkstra算法 259

14.3 Bellman-Ford算法 264

14.4有向无环图中的最短路径 266

14.5所有顶点对之间的最短路径 268

14.5.1动态规划最短路径算法 268

14.5.2通过矩阵乘法计算最短路径 269

14.6练习 272

本章注记 275

第15章 最小生成树 276

15.1最小生成树的性质 276

15.2 Kruskal算法 279

15.3 Prim-Jarnik算法 282

15.4 Baruvka算法 285

15.5练习 286

本章注记 288

第16章 网络流和匹配 290

16.1流与割 290

16.1.1割 292

16.1.2剩余容量和增流路径 293

16.2最大流算法 295

16.2.1 Ford-Fulkerson算法 295

16.2.2 Edmonds-Karp算法 297

16.3最大二分图匹配 300

16.4棒球赛的淘汰 301

16.5最低成本流 302

16.6练习 307

本章注记 309

第五部分 计算困难问题 312

第17章 NP完全性 312

17.1 P和NP 313

17.1.1定义复杂类P和NP 314

17.1.2一些有趣的NP问题 316

17.2 NP完全性 318

17.2.1多项式时间归约和NP难度 318

17.2.2 Cook-Levin定理 318

17.2.3如何证明一个问题是NP完全问题 319

17.3合取范式可满足问题和3可满足问题 321

17.4顶点覆盖、团和集合覆盖 324

17.5子集和与背包问题 326

17.6哈密顿回路和TSP 328

17.7练习 330

本章注记 333

第18章 近似算法 334

18.1几何旅行商问题 336

18.1.1 Metric-TSP的一个2近似算法 336

18.1.2 Christofides近似算法 337

18.2覆盖问题的近似 338

18.2.1顶点覆盖的2近似算法 338

18.2.2集合覆盖的对数近似 339

18.3多项式时间近似方法 340

18.4回溯和分支定界 342

18.4.1回溯法 342

19.4.2分支定界法 344

18.5练习 344

本章注记 346

第六部分 高级主题 350

第19章 随机算法 350

19.1随机排列的生成 351

19.2稳定婚姻和优惠券收集 352

19.2.1优惠券收集问题分析 353

19.2.2稳定婚姻问题 354

19.3最小割 356

19.3.1收缩边 357

19.3.2计算最小割 357

19.3.3更快的算法 359

19.4寻找素数 360

19.5切尔诺夫界 364

19.5.1马尔可夫不等式 364

19.5.2示性随机变量之和 364

19.5.3几何型随机变量之和 366

19.6跳跃表 367

19.6.1搜索 368

19.6.2更新操作 368

19.6.3跳跃表的概率分析 370

19.7练习 371

本章注记 374

第20章 B树和外部存储器 376

20.1外部存储器 377

20.2 (2,4)树和B树 379

20.2.1多叉搜索树 379

20.2.2(2,4)树 381

20.2.3 (a,b)树和B树 386

20.3外部存储器排序 389

20.4在线缓存算法 391

20.5练习 396

本章注记 398

第21章 多维搜索 399

21.1范围树 400

21.2优先搜索树 403

21.2.1构造优先搜索树 403

21.2.2在优先搜索树中搜索 404

21.2.3优先范围树 405

21.3四叉树和k-d树 406

21.3.1四叉树 406

21.3.2 k-d树 407

21.4练习 409

本章注记 411

第22章 计算几何 412

22.1几何对象上的操作 413

22.2凸壳 416

22.2.1礼品包装算法 417

22.2.2 Graham扫描算法 419

22.3线段相交 421

22.4求最近点对 423

22.5练习 425

本章注记 428

第23章 字符串算法 429

23.1字符串操作 430

23.2 Boyer-Moore算法 431

23.3 Knuth-Morris-Pratt算法 435

23.4基于散列的词典匹配 437

23.5字典树 441

23.5.1标准字典树 441

23.5.2压缩字典树 443

23.5.3后缀字典树 445

23.5.4搜索引擎 447

23.6练习 448

本章注记 450

第24章 密码学 451

24.1最大公约数 452

24.1.1一些初等数论知识 452

24.1.2欧几里得GCD算法 453

24.2模运算 454

24.2.1模幂运算 456

24.2.2模乘法逆 458

24.3加密操作 459

24.4 RSA密码系统 461

24.5 El Gamal密码系统 463

24.6练习 464

本章注记 465

第25章 快速傅里叶变换 466

25.1卷积 467

25.2原始单位根 468

25.3离散傅里叶变换 469

25.4快速傅里叶变换算法 471

25.5练习 475

本章注记 478

第26章 线性规划 479

26.1定义问题 480

26.2单纯形法 483

26.2.1松弛型 484

26.2.2扩展的例子 485

26.2.3单纯形算法 487

26.3对偶 488

26.4线性规划的应用 491

26.5练习 492

本章注记 497

附录A一些有用的数学知识 498

参考文献 501