豆瓣评分9.5,哈佛、斯坦福、普林斯顿等都在用的算法经典教材

简介:   先看看作者吧,Jon Kleinberg是美国国家科学院(NAS)、美国国家工程院(NAE)、美国人文与科学院(AAAS)三料院士,在计算机科学领域是“传说级”的人物。而且他还获得过国际数学家大会颁发“奈望林纳奖”,这个奖是数学家大会为了表彰信息科学方面的重要数学贡献而设的。——来自豆瓣

  先看看作者吧,Jon Kleinberg是美国国家科学院(NAS)、美国国家工程院(NAE)、美国人文与科学院(AAAS)三料院士,在计算机科学领域是“传说级”的人物。而且他还获得过国际数学家大会颁发“奈望林纳奖”,这个奖是数学家大会为了表彰信息科学方面的重要数学贡献而设的。——来自豆瓣

  算法设计

  作者乔恩·克莱因伯格(Jon Kleinberg) 是康奈尔大学计算机科学教授。他于 1996 年从麻省理工学院获得博士学位。他荣获过美国国家科学基金会事业奖 (NSF Career Award)、海军研究局青年研究员奖(ONR Young Investigator Award)、IBM 杰出创新奖(IBM Outstanding Innovation Award)、美国国家科 学院创新研究奖(National Academy of Sciences Award for Initiatives in Research),还获得过帕卡德基金会(Packard Foundation)和斯隆基金会(Sloan Foundation)的研究基金以及康奈尔工程学院与计算机科学系教学奖。

  克莱因伯格的研究集中在算法上,特别是与网络结构和信息相关的算法,以及这些算法在 信息科学、优化、数据挖掘及计算生物学等方面的应用。他利用信息中心和权威信息进行网络 分析的工作,对形成最新一代因特网搜索引擎的基础起了很大的作用。

  >>>> 正如书名所言,这本教材通篇都在讲述“如何针对具体问题设计算法”。 很喜欢这本书场景引出问题=>设计算法解决=>分析算法的结构,让人对问题所描述的内容更感兴趣,对算法所应用的场景印象也更加深刻。 以动态规划这个主题而言,在第一章就通过“如何高效分配会议室等资源”这个问题来引出具体算法:如果通过资源利用时长来衡量那么贪心算法显然是最符合直觉的;但如果引入了“权重”这个概念,那么贪心算法就不够用了。解决“加权区间调度”问题的更好方式是动态规划。 在第六章先以递归暴力求解,再优化、分析这个算法,进而抽象出动态规划的特征:先解决“多项式”个子问题、再从子问题的解计算出原始问题的解——来自豆瓣

  >>>> 这本书不光细节满满,每章后面的带解答练习更是点睛之笔,一般书中的习题答案要么是最后解,要么简单的分析,这本书的建议解答几乎把每一个点都写在书中,让人更容易理解其意。

  本书带入的算法研究,始于各种计算应用程序中出现的问题,构建在对算法设计技术理解基础之上,最终得到这些问题的有效解决方案。——来自豆瓣

  >>>> 本书是IT人员改变码农身份和命运的力作,特别是立志于SDN和智能化网络管理系统设计和研发的IT人员应该要好好研读的佳作。——来自豆瓣

  算法设计

  这是一本被众多名校采用的算法设计课程教材,强调用实际示例阐明枯燥的算法理论,更注重算法设计思路而非算法复杂度分析。本书采用新颖的教学方式,通过分析真实世界的问题来激发算法思想。两位作者以一种清晰、直接的方式,指导学生自己分析和定义问题,并从中找出适用于给定场景的算法设计原则。本书鼓励读者更深入地理解算法设计过程,探索算法在计算机科学的更广阔领域中的应用。

  本书具有以下特色:

  强调问题分析和设计方法;

  遵循结构化教学法,引导学生掌握问题形式化、算法设计和算法分析的全过程;

  通过一系列带解答的问题,展示计算机科学家设计和应用算法的过程;

  包含 200 多道作业题,其中一些题目出自 Yahoo! 和 Oracle 等公司;

  提供广泛用于处理 NP 困难问题和随机应用的算法,这些是极其重要的算法主题。

  算法这一主题是一个强大的“镜头”,透过 它可以查看计算机科学领域。算法问题构成了计算机科学的核心, 但它们很少以整洁、精确的 数学问题的形式出现。相反, 它们往往有许多杂乱的、应用程序特定的细节,由一些至关重要 和一些无关紧要的东西纠缠在一起。因此, 算法问题由两个基本部分组成:得到数学上整洁的 问题核心, 然后根据问题结构确定适当的算法设计技术。这两个部分相互影响: 越能自如地运 用各种可能的设计技术, 也就越能认识到世上混乱问题中的整洁形式描述。在最有效的情况下, 算法思想不但能提供适当问题的解决方案, 而且它们构成了一种语言, 让你可以清晰地表达基 本问题。

  本书的目标是将这种方法带入算法研究,作为一个设计过程,它始于各种计算应用程序中 出现的问题,构建在对算法设计技术理解的基础之上,最终得到这些问题的减肥解决方案。我 们试图探讨算法思想在计算机科学中的作用,并将这些思想与一些精确制定的问题联系起来, 我们可以为它们设计算法并进行分析。换言之,导致这些问题的根本问题是什么?如何选择这 些特定的方式来描述它们?如何认识到不同情况下适用哪些设计原则?

  “这(本书)是我看过的非常优秀的本科生教材,我认为它将为算法教材的新时代奠定基础……(它采用)新颖的教学方式,更强调算法的设计,并且配有丰富的练习。”

  ——Dieter van Melkebeek,威斯康星大学麦迪逊分校

  “这本书完美融合了直觉和严密性,包含了计算机科学所有领域的各种奇妙的应用,并且提供了独特的问题分析和算法设计方法……”

  ——Anna R. Karlin,华盛顿大学

  “两位作者将算法思想与真实问题联系起来的工作极其了不起,并且完成得非常精彩。”

  ——Michael Mitzenmacher,哈佛大学

  第 1章 引言:一些典型问题 1

  1.1 第 一个问题:稳定匹配 1

  1.2 5个典型问题 8

  带解答的练习 12

  练习 14

  注释和进一步阅读 17

  第 2章 算法分析基础 18

  2.1 计算可解性 18

  2.2 增长的渐近阶 21

  2.3 用列表和数组实现稳定匹配算法 26

  2.4 常见运行时间综述 29

  2.5 更复杂的数据结构:优先队列 35

  带解答的练习 40

  练习 41

  注释和进一步阅读 44

  第3章 图 45

  3.1 基本定义和应用 45

  3.2 图连通性和图遍历 48

  3.3 用队列和栈实现图遍历 53

  3.4 二分性测试:广度优先搜索的应用 58

  3.5 有向图中的连通性 59

  3.6 有向无环图和拓扑排序 61

  带解答的练习 64

  练习 66

  注释和进一步阅读 69

  第4章 贪心算法 70

  4.1 区间调度:贪心算法保持领先 70

  4.2 最小化延迟的调度:交换论证 76

  4.3 最优缓存:更复杂的交换论证 80

  4.4 图的最短路径 83

  4.5 最小生成树问题 87

  4.6 实现Kruskal算法:Union-Find数据结构 92

  4.7 聚类 97

  4.8 哈夫曼码和数据压缩 99

  *4.9 最小开销树形图:多阶段贪心算法 109

  带解答的练习 113

  练习 116

  注释和进一步阅读 125

  第5章 分治 127

  5.1 第 一个递推式:归并排序算法 127

  5.2 进一步的递推关系 130

  5.3 计数逆序 134

  5.4 寻找最近点对 137

  5.5 整数乘法 141

  5.6 卷积和快速傅里叶变换 142

  带解答的练习 148

  练习 150

  注释和进一步阅读 152

  第6章 动态规划 153

  6.1 加权区间调度:递归过程 153

  6.2 动态规划原理:备忘录或子问题迭代 157

  6.3 分段最小二乘:多重选择 159

  6.4 子集和与背包:加一个变量 162

  6.5 RNA二级结构:区间上的动态规划 166

  6.6 序列比对 169

  6.7 通过分治在线性空间中序列比对 173

  6.8 图中的最短路径 177

  6.9 最短路径和距离向量协议 182

  *6.10 图中的负环 184

  带解答的练习 187

  练习 190

  注释和进一步阅读 204

  第7章 网络流 205

  7.1 最大流问题和Ford-Fulkerson算法 205

  7.2 网络中的最大流和最小割 211

  7.3 选择好的增广路径 214

  *7.4 预流推进最大流算法 218

  7.5 第 一个应用:二分匹配问题 225

  7.6 有向图和无向图中的不相交路径 228

  7.7 最大流问题的扩展 232

  7.8 调查设计 236

  7.9 航空公司调度 237

  7.10 图像分割 240

  7.11 项目选择 243

  7.12 棒球排除 246

  *7.13 进一步的方向:为匹配问题增加开销 249

  带解答的练习 253

  练习 255

  注释和进一步阅读 274

  第8章 NP和计算难解性 276

  8.1 多项式时间归约 276

  8.2 通过“小配件”归约:可满足性问题 280

  8.3 有效证书和NP的定义 283

  8.4 NP完全问题 285

  8.5 排序问题 289

  8.6 划分问题 294

  8.7 图着色 297

  8.8 数值问题 300

  8.9 co-NP和NP的不对称性 303

  8.10 困难问题的部分分类 305

  带解答的练习 307

  练习 309

  注释和进一步阅读 323

  第9章 PSPACE:NP之外的一类问题 324

  9.1 PSPACE 324

  9.2 PSPACE中的一些难题 325

  9.3 在多项式空间中求解量化问题和博弈 327

  9.4 在多项式空间中求解规划问题 328

  9.5 证明问题是PSPACE完全的 331

  带解答的练习 334

  练习 335

  注释和进一步阅读 336

  第 10章 扩展易解性的界限 337

  10.1 寻找小的顶点覆盖 338

  10.2 求解树上的NP困难问题 340

  10.3 圆弧集着色 343

  *10.4 图的树分解 349

  *10.5 构造树分解 356

  带解答的练习 361

  练习 363

  注释和进一步阅读 365

  第 11章 近似算法 366

  11.1 贪心算法和最优值的界限:负载均衡问题 366

  11.2 中心选址问题 370

  11.3 集合覆盖:一般贪心启发式 374

  11.4 定价方法:顶点覆盖 378

  11.5 用定价方法最大化:不相交路径问题 382

  11.6 线性规划和舍入:顶点覆盖的应用 386

  *11.7 再论负载均衡:更高级的LP应用 390

  11.8 任意好的近似:背包问题 394

  带解答的练习 398

  练习 399

  注释和进一步阅读 404

  第 12章 局部搜索 406

  12.1 优化问题的地形 406

  12.2 Metropolis算法和模拟退火算法 409

  12.3 局部搜索在Hopfield神经网络中的应用 412

  12.4 通过局部搜索的最大割近似 415

  12.5 选择邻居关系 417

  *12.6 用局部搜索分类 418

  12.7 最优响应动态和纳什均衡 423

  带解答的练习 430

  练习 431

  注释和进一步阅读 433

  第 13章 随机算法 434

  13.1 第 一个应用:消除争用 435

  13.2 寻找全局最小割 438

  13.3 随机变量及其期望 442

  13.4 MAX 3-SAT的随机近似算法 445

  13.5 随机分治:找中位数和Quicksort 447

  13.6 哈希:字典的随机实现 452

  13.7 寻找最近点对:随机方法 457

  13.8 随机缓存 462

  13.9 切尔诺夫界 467

  13.10 负载均衡 468

  13.11 分组路由 470

  13.12 背景知识:一些基本概率定义 474

  带解答的练习 479

  练习 483

  注释和进一步阅读 489

  后记:永远运行的算法 491

  参考文献 497

目录
相关文章
|
8月前
|
机器学习/深度学习 算法 数据可视化
Matlab决策树、模糊C-均值聚类算法分析高校教师职称学历评分可视化
Matlab决策树、模糊C-均值聚类算法分析高校教师职称学历评分可视化
|
存储 算法 API
Elasticsearch评分相关度算法解析
Elasticsearch评分相关度算法解析
155 0
|
机器学习/深度学习 算法 BI
逆向倾向评分 (Inverse Propensity Scoring, IPS) 原理解析与MF算法的结合使用
逆向倾向评分 (Inverse Propensity Scoring, IPS) 原理解析与MF算法的结合使用
|
机器学习/深度学习 人工智能 算法
AI生成高数题,难出新高度:MIT提出首个可出题、做题、评分的算法模型
AI生成高数题,难出新高度:MIT提出首个可出题、做题、评分的算法模型
781 0
|
算法 搜索推荐 索引
Elasticsearch相关度评分算法(三):BM25(Okapi BM25)
Elasticsearch相关度评分算法(三):BM25(Okapi BM25)
Elasticsearch相关度评分算法(三):BM25(Okapi BM25)
|
机器学习/深度学习 人工智能 算法
|
机器学习/深度学习 人工智能 算法
2019 年 11 月最新《TensorFlow 2.0 深度学习算法实战》中文版教材免费开源(附随书代码+pdf)
2019 年 11 月最新《TensorFlow 2.0 深度学习算法实战》中文版教材免费开源(附随书代码+pdf)
417 0
2019 年 11 月最新《TensorFlow 2.0 深度学习算法实战》中文版教材免费开源(附随书代码+pdf)
ML之回归预测之Lasso:利用Lasso算法解决回归(实数值评分预测)问题—优化模型【增加新(组合)属性】
ML之回归预测之Lasso:利用Lasso算法解决回归(实数值评分预测)问题—优化模型【增加新(组合)属性】
ML之回归预测之Lasso:利用Lasso算法解决回归(实数值评分预测)问题—优化模型【增加新(组合)属性】
ML之回归预测之Lasso:利用Lasso算法对红酒品质wine数据集实现红酒口感评分预测(实数值评分预测)
ML之回归预测之Lasso:利用Lasso算法对红酒品质wine数据集实现红酒口感评分预测(实数值评分预测)
ML之回归预测之Lasso:利用Lasso算法对红酒品质wine数据集实现红酒口感评分预测(实数值评分预测)
ML之回归预测之Lasso:利用Lasso算法解决回归(实数值评分预测)问题—采用10折交叉验证(测试集error)来评估LassoCV模型
ML之回归预测之Lasso:利用Lasso算法解决回归(实数值评分预测)问题—采用10折交叉验证(测试集error)来评估LassoCV模型
ML之回归预测之Lasso:利用Lasso算法解决回归(实数值评分预测)问题—采用10折交叉验证(测试集error)来评估LassoCV模型

热门文章

最新文章