Introduction to Algorithms 2nd ed. Cambridge, MA: MIT Press, 2001. ISBN: 9780262032933.

Introduction and document distance

L1

Introduction and document distance

CLRS, chapters 1-3

L2

More document distance, mergesort

CLRS, sections 11.1-11.2

Binary search trees

L3

Airplane scheduling, binary search trees

CLRS, chapter 10 and sections 12.1-12.3

L4

Balanced binary search trees

CLRS, sections 13.1 and 13.2 for a different approach (red-black trees)

Hashing

L5

Hashing I: chaining, hash functions

L6

Hashing II:
table doubling, Karp-Rabin

CLRS,
chapter 17 and section 32.2

L7

Hashing
III: open addressing

CLRS,
section 11.4 (and 11.3.3 and 11.5 if interested)

Sorting

L8

Sorting I:
heaps

CLRS,
sections 2.1-2.3 and 6.1-6.2

L9

Sorting II:
heaps

CLRS,
sections 6.1-6.4

L10

Sorting
III: lower bounds, linear-time sorting

CLRS,
sections 8.1-8.4

L11

Sorting IV:
stable sorting, radix sort

Searching

L12

Searching
I: graph search, representations, and applications

CLRS,
sections 22.1-22.3 and B.4

L13

Searching
II: breadth-first search and depth-first search

CLRS,
sections 22.2-22.3

L14

Searching
III: topological sort and NP-completeness

CLRS,
sections 22.4 and 34.1-34.3 (at a high level)

Shortest
paths

L15

Shortest
paths I: intro

CLRS,
chapter 24 (intro)

L16

Shortest
paths II: Bellman-Ford

L17

Shortest
paths III: Dijkstra

CLRS,
sections 24.2-24.3

L18

Shortest
paths IV: Dijkstra speedups

Wagner,
Dorothea, and Thomas Willhalm. "Speed-Up Techniques for Shortest-Path
Computations." In Lecture Notes in Computer Science: Proceedings of
the 24th Annual Symposium on Theoretical Aspects of Computer Science
.
Berlin / Heidelberg: Springer, 2007. ISBN: 9783540709176. Read up to section
3.2.

Dynamic
programming

L19

Dynamic programming
I: memoization, Fibonacci, Crazy Eights, guessing

CLRS,
chapter 15

L20

Dynamic
programming II: longest common subsequence, parent pointers

L21

Dynamic
programming III: text justification, parenthesization, knapsack,
pseudopolynomial time, Tetris training

L22

Dynamic
programming IV: piano fingering, structural DP (trees), vertex cover,
dominating set, and beyond

For fun,
see papers on piano fingering and polyphonic piano fingering via DP:

Parncutt,
Richard, et al. "An Ergonomic Model of Keyboard Fingering for Melodic
Fragments." Music Perception 14, no. 4 (1997): 341-382.

Al Kasimi,
Alia, Eric Nichols, and Christopher Raphael. "A Simple Algorithm for
Automatic Generation of Polyphonic Piano Fingerings." In Proceedings
of the 8th International Conference on Music Information Retrieval
, 2007,
pp. 355-356.

For fun,
watch the Metamorphosis of the Cube video,
which illustrates a folding DP.

Numerics

L23

Numerics I

L24

Numerics II

Beyond
6.006

L25

Beyond
6.006: follow-on classes, geometric folding algorithms

Reading task(Introduction to Algorithms. 2nd)的更多相关文章

  1. [翻译] 提升树算法的介绍(Introduction to Boosted Trees)

    [翻译] 提升树算法的介绍(Introduction to Boosted Trees) 1. 有监督学习的要素 XGBoost 适用于有监督学习问题.在此类问题中,我们使用多特征的训练数据集 \(x ...

  2. 图形上下文导论(Introduction to SWT Graphics)zz

    图形上下文导论(Introduction to SWT Graphics) 摘要: org.eclipse.swt.graphics包(package),包含了管理图形资源的类.只要实现了org.ec ...

  3. 6.006 Introduction to Algorithms

    课程信息 6.006 Introduction to Algorithms

  4. 算法导论(Introduction to Algorithms )— 第十二章 二叉搜索树— 12.1 什么是二叉搜索树

    搜索树数据结构支持很多动态集合操作,如search(查找).minmum(最小元素).maxmum(最大元素).predecessor(前驱).successor(后继).insert(插入).del ...

  5. note of introduction of Algorithms(Lecture 3 - Part1)

    Lecture 3(part 1) Divide and conquer 1. the general paradim of algrithm as bellow: 1. divide the pro ...

  6. hdu 1885 Key Task(bfs+状态压缩)

    Problem Description The Czech Technical University years of its existence . Some of the university b ...

  7. hdu 3572 Task Schedule (dinic算法)

    pid=3572">Task Schedule Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  8. C#多线程编程のTask(任务全面解析)

    Task是.NET4.0加入的,跟线程池ThreadPool的功能类似,用Task开启新任务时,会从线程池中调用线程,而Thread每次实例化都会创建一个新的线程. 我们可以说Task是一种基于任务的 ...

  9. 课程一(Neural Networks and Deep Learning),第一周(Introduction to Deep Learning)—— 2、10个测验题

    1.What does the analogy “AI is the new electricity” refer to?  (B) A. Through the “smart grid”, AI i ...

随机推荐

  1. Composer基本安装步骤

    Composer是 PHP 世界里用于管理项目依赖的工具. 1,确保安装PHP,检查方法命令行窗口执行php -v,查看是否正常输出版本 php -v 2,下载安装脚本composer-setup.p ...

  2. Spring Boot + Websocket + Thymeleaf + Lombok

    https://github.com/guillermoherrero/websocket 验证错误消息文件名字:是默认名ValidationMessages.properties,编译后存放在cla ...

  3. aliyun oss操作汇总

    // endpoint以杭州为例,其它region请按实际情况填写 String endpoint = "http://oss-cn-hangzhou.aliyuncs.com"; ...

  4. websocket(一)--握手

    最近在琢磨怎么实现服务端的消息推送,因为以前都是通过客户端请求来获取信息的,如果需要实时信息就得轮询,比如通过ajax不停的请求. websocket相当于对HTTP协议进行了升级,客户端和服务端通过 ...

  5. textarea去掉右下角拖拽

    /*去掉textarea右下角三角符号*/ resize : none;

  6. layer使用总结

    1.询问框的使用 主要体现在删除等重要操作 让用户进行二次确认的场景 //询问框 layer.confirm('您是如何看待前端开发?', { btn: ['重要','奇葩'] //按钮 }, fun ...

  7. js默认参数实现方法

    function simue (){ var a = arguments[0] ? arguments[0] : 1; var b = arguments[1] ? arguments[1] : 2; ...

  8. i春秋——Misc之百度杯

    今天心里很是不开森,想想往日何必那么努力呢?不如你的比比皆是,可是人家就是因为有关系,你又能怎样呢? 你所有应该有的都被打翻了,别灰心,至少你曾经努力过! 愿我未来的学弟学妹们都能一直开开心心的过好每 ...

  9. 让你分分钟理解 JavaScript 闭包

    闭包,是 Javascript 比较重要的一个概念,对于初学者来讲,闭包是一个特别抽象的概念,特别是 ECMAScript 规范给的定义,如果没有实战经验,很难从定义去理解它.因此,本文不会对闭包的概 ...

  10. Python爬虫入门教程 56-100 python爬虫高级技术之验证码篇2-开放平台OCR技术

    今日的验证码之旅 今天你要学习的验证码采用通过第三方AI平台开放的OCR接口实现,OCR文字识别技术目前已经比较成熟了,而且第三方比较多,今天采用的是百度的. 注册百度AI平台 官方网址:http:/ ...