第一部分 基础知识

第1章 算法在计算中的作用

第2章 算法基础

第3章 函数的增长

第4章 分治策略

第5章 概率分析和随机算法

第二部分 排序和顺序统计量

第6章 堆排序

第7章 快速排序

第8章 线性时间排序

第9章 中位数和顺序统计量

第三部分 数据结构

第10章 基本数据结构

第11章 散列表

第12章 二叉搜索树

第13章 红黑树

第14章 数据结构的扩张

第四部分 高级设计和分析技术

第15章 动态规划

第16章 贪心算法

第17章 摊还分析

第五部分 高级数据结构

第18章 B树

第19章 斐波那契堆

第20章 van Emde Boas 树

第21章 用于不相交集合的数据结构

第六部分 图算法

第22章 基本的图算法

第23章 最小生成树

第24章 单源最短路径

第25章 所有结点对的最短路径问题

第26章 最大流

第七部分 算法问题选编

第27章 多线程算法

第28章 矩阵运算

第29章 线性规划

第30章 多项式与快速傅里叶变换

第31章 数论算法

第32章 字符串匹配

第33章 计算几何学

第34章 NP完全性

第35章 近似算法

---------------------------------------------------------------------------------------------------------------------------------------------------------------

第1章 算法在计算中的作用

思考题

1-1 (运行时间的比较) 假设求解问题的算法需要f(n)毫秒,对下表中的每个函数f(n)和时间t,确定可以在时间t内求解的问题的最大规模n

  1秒钟 1分钟 1小时 1天 1月 1年 1世纪
lgn              
sqrt(n)              
n              
nlgn              
n^2              
n^3              
2^n              
n!              

第2章 算法基础

练习

2.2-1 用 记号表示函数n^3/1000-100n^2-100n+3

Θ(n^3)

2.2-2 考虑排序存储在数组A中的n个数:首先找出A中的最小元素并将其与A[1]中的元素进行交换.接着,找出A中的次最小元素并将其与A[2]中的元素进行交换.对A中前n-1个元素按该方式继续.该算法称为选择算法,写出其伪代码.该算法维持的循环不变式是什么?为什么它只需要对前n-1个元素,而不是对所有n个元素运行?用Θ记号给出选择排序的最好情况与最坏情况运行时间.

2.2-3 再次考虑线性查找问题(参见练习2.1-3).假定要查找的元素等可能地为数组中的任意元素,平均需要检查输入序列的多少元素?最坏情况又如何呢?用Θ记号给出线性查找的平均情况和最坏情况运行时间.证明你的答案.

2.2-4 应该如何修改任何一个算法,才能使之具有良好的最好情况运行时间?

第3章 函数的增长

第4章 分治策略

第5章 概率分析和随机算法

第6章 堆排序

第7章 快速排序

第8章 线性时间排序

第9章 中位数和顺序统计量

第10章 基本数据结构

第11章 散列表

第12章 二叉搜索树

第13章 红黑树

第14章 数据结构的扩张

第15章 动态规划

第16章 贪心算法

第17章 摊还分析

第18章 B树

第19章 斐波那契堆

第20章 van Emde Boas 树

第21章 用于不相交集合的数据结构

第22章 基本的图算法

第23章 最小生成树

第24章 单源最短路径

第25章 所有结点对的最短路径问题

第26章 最大流

第27章 多线程算法

第28章 矩阵运算

第29章 线性规划

第30章 多项式与快速傅里叶变换

第31章 数论算法

第32章 字符串匹配

第33章 计算几何学

第34章 NP完全性

第35章 近似算法

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------

https://ita.skanev.com/

算法导论 (Thomas H.Cormen / Charles E.Leiserson / Ronald L.Rivest / Clifford Stein 著)的更多相关文章

  1. MIT算法导论——第二讲.Solving Recurrence

    本栏目(Algorithms)下MIT算法导论专题是个人对网易公开课MIT算法导论的学习心得与笔记.所有内容均来自MIT公开课Introduction to Algorithms中Charles E. ...

  2. MIT算法导论——第五讲.Linear Time Sort

    本栏目(Algorithms)下MIT算法导论专题是个人对网易公开课MIT算法导论的学习心得与笔记.所有内容均来自MIT公开课Introduction to Algorithms中Charles E. ...

  3. MIT算法导论——第一讲.Analysis of algorithm

    本栏目(Algorithms)下MIT算法导论专题是个人对网易公开课MIT算法导论的学习心得与笔记.所有内容均来自MIT公开课Introduction to Algorithms中Charles E. ...

  4. MIT算法导论——第四讲.Quicksort

    本栏目(Algorithms)下MIT算法导论专题是个人对网易公开课MIT算法导论的学习心得与笔记.所有内容均来自MIT公开课Introduction to Algorithms中Charles E. ...

  5. MIT算法导论——第三讲.The Divide-and-Conquer

    本栏目(Algorithms)下MIT算法导论专题是个人对网易公开课MIT算法导论的学习心得与笔记.所有内容均来自MIT公开课Introduction to Algorithms中Charles E. ...

  6. B树——算法导论(25)

    B树 1. 简介 在之前我们学习了红黑树,今天再学习一种树--B树.它与红黑树有许多类似的地方,比如都是平衡搜索树,但它们在功能和结构上却有较大的差别. 从功能上看,B树是为磁盘或其他存储设备设计的, ...

  7. 红黑树——算法导论(15)

    1. 什么是红黑树 (1) 简介     上一篇我们介绍了基本动态集合操作时间复杂度均为O(h)的二叉搜索树.但遗憾的是,只有当二叉搜索树高度较低时,这些集合操作才会较快:即当树的高度较高(甚至一种极 ...

  8. 堆排序与优先队列——算法导论(7)

    1. 预备知识 (1) 基本概念     如图,(二叉)堆是一个数组,它可以被看成一个近似的完全二叉树.树中的每一个结点对应数组中的一个元素.除了最底层外,该树是完全充满的,而且从左向右填充.堆的数组 ...

  9. 算法导论第十八章 B树

    一.高级数据结构 本章以后到第21章(并查集)隶属于高级数据结构的内容.前面还留了两章:贪心算法和摊还分析,打算后面再来补充.之前的章节讨论的支持动态数据集上的操作,如查找.插入.删除等都是基于简单的 ...

随机推荐

  1. HP Instant Information

    HP Instant Information before HP-UX 11i v3 <管理系统和工作组:HP-UX系统管理员指南> After HP-UX 11i v3 <HP-U ...

  2. Find the Missing Number II

    Giving a string with number from 1-n in random order, but miss 1 number.Find that number. Notice n & ...

  3. :命令模式:Command

    #ifndef __COMMAND_H__ #define __COMMAND_H__ #include <vector> #include "Equipment.h" ...

  4. C语言获取系统时间的几种方式

    C语言获取系统时间的几种方式 2009-07-22 11:18:50|  分类: 编程学习 |字号 订阅     C语言中如何获取时间?精度如何? 1 使用time_t time( time_t * ...

  5. FutureTask

    因为实现了runnable接口,所以重写了run方法 Future接口如果用在多线程中,实现类一般是有一个volatile的属性,用来标志状态,比如state,如果事情做完了,那么会设置state为成 ...

  6. 软件工程项目程序:WC

    1:代码来源:http://yuncode.net/code/c_5087c8e4cd77190 2:Platform:Eclipse Language:Java 3:Bug:暂时没有 4. Func ...

  7. nginx随机模块——ngx_http_random_index_module

    今天我给大家分享一个挺好玩的模块,随机变换网站首页的模块 这个模块他的作用于只有在location中,具体写法如下 只需要在localtion开启这个模块就好了,然后呢我们在/usr/share/ng ...

  8. C# 创建 写入 读取 excel

    public static void CreateExcelFile(string FileName, List<UUser> luu) { ] == "xlsx")/ ...

  9. smali语法详解

    smali文件格式 每个smali文件都由若干条语句组成,所有的语句都遵循着一套语法规则.在smali 文件的头3 行描述了当前类的一些信息,格式如下: .class < 访问权限> [  ...

  10. 1.4 Chrome浏览器

    1.4 Chrome浏览器 前言selenium2启动Chrome浏览器是需要安装驱动包的,但是不同的Chrome浏览器版本号,对应的驱动文件版本号又不一样,如果版本号不匹配,是没法启动起来的. ## ...