简年2: 《算法导论》--循环不变式+排序算法

开篇语

今天开始看《算法导论》的第二章--算法基础,主要内容是讲述了循环不变式以及排序算法的设计以及复杂度的计算,文中巧妙地运用了扑克牌的插牌来形象的表达了排序算法的内在内容,十分的生动形象。

扑克牌抓牌解释排序算法

正文

一、插入算法

循环不变式三性质:
  1. 初始化(循环第一次迭代之前)的时候,它为真;
  1. 如果循环的某次迭代之前它为真,那么下次迭代之前它仍为真;
  2. 循环结束的时候,不变式为我们提供一个有用的性质,该性质有助于证明算法是正确的。
三性质
伪代码的一些规定:
还有一部分就不做多的描述了。大家有兴趣的自己网购算法导论或者去图书馆借阅都可以
排序中的插入算法:
INSERTION-SORT(A)   #A是一个等待排序的数组
1    for j=2 to A.length
2      key=A[j]
3      //Insert A[j] into the sorted qequence A[1..j-1]      #把数组中的第j个数字取出来
4      i=j-1
5      while i>0 and A[i]>key   //取出已经排好的前面的,如果满足取出的数大于小于之排好的数,那么进入循环
6          A[i+1]=A[i]
7          i=i-1   //将大的数放到高序号,然后再次对更加之前的数进行比较。
8       A[i+1]=key


插入算法

插入算法如果类比到插牌的过程中,那么就是类似一把牌,按照从左到右大小的顺序排好,那么每抽上来一只牌,都与目前最右边的进行比较, 如果比它大,那么就放在最右边;如果比它小,那么就与右边数过来第二张进行比较。直到找到比它小的那张牌,就插在那张牌的右边。

循环不变式与插入排序的正确性
算法的复杂度分析

定义:如果一个问题的规模是n,解这一问题的某一算法所需要的时间为T(n),它是n的某一函数 T(n)称为这一算法的“时间复杂性”。

当输入量n逐渐加大时,时间复杂性的极限情形称为算法的“渐近时间复杂性”。

我们常用大O表示法表示时间复杂性,注意它是某一个算法的时间复杂性。大O表示只是说有上界,由定义如果f(n)=O(n),那显然成立f(n)=O(n^2),它给你一个上界,但并不是上确界,但人们在表示的时候一般都习惯表示前者。

此外,一个问题本身也有它的复杂性,如果某个算法的复杂性到达了这个问题复杂性的下界,那就称这样的算法是最佳算法。

“大O记法”:在这种描述中使用的基本参数是 n,即问题实例的规模,把复杂性或运行时间表达为n的函数。这里的“O”表示量级 (order),比如说“二分检索是** O(logn)**的”,也就是说它需要“通过logn量级的步骤去检索一个规模为n的数组”记法 O ( f(n) )表示当 n增大时,运行时间至多将以正比于 f(n)的速度增长。

这种渐进估计对算法的理论分析和大致比较是非常有价值的,但在实践中细节也可能造成差异。例如,一个低附加代价的O(n^2)算法在n较小的情况下可能比一个高附加代价的 O(nlogn)*算法运行得更快。当然,随着n足够大以后,具有较慢上升函数的算法必然工作得更快。

插入算法的复杂度分析

对给定规模的输入,一个算法的运行时间可能结果如下图,对我们本次讲解的插入算法,最佳情况是:T(n)=an+b;最差的结果是:T(n)=an^2+bn+c

对给定规模的输入,一个算法的运行时间可能结果

二、分治法

分治法的设计思想是:将一个难以直接解决的大问题,分割成一些规模较小的相同问题,以便各个击破,分而治之。

分治法定义
分治法的步骤
伪代码

伪代码
分治法分解之后合并所需要的算法的伪代码
MERGE(A,p,q,r)

1  n1=q-p+1
2  n2=r-q
3  let L[1..n1+1] and R[1..n2+1] be new arrays
4  for i=1 to n1
5    L[i]=A[p+i-1]
6  for j=1 to n2
7    R[j]=A[q+j]
8  L[n1+1]=&
9  R[n2+1]=&
10  i=1
11  j=1
12  for k=p to r
13    if L[i]<=R[j]
14      A[k]=L[i]
15      i=i+1
16    else A[k]=R[j]
17      j=j+1

分治策略是:对于一个规模为n的问题,若该问题可以容易地解决(比如说规模n较小)则直接解决,否则将其分解为k个规模较小的子问题,这些子问题互相独立且与原问题形式相同,递归地解这些子问题,然后将各子问题的解合并得到原问题的解。这种算法设计策略叫做分治法。

如果原问题可分割成k个子问题,1<k≤n,且这些子问题都可解并可利用这些子问题的解求出原问题的解,那么这种分治法就是可行的。由分治法产生的子问题往往是原问题的较小模式,这就为使用递归技术提供了方便。在这种情况下,反复应用分治手段,可以使子问题与原问题类型一致而其规模却不断缩小,最终使子问题缩小到很容易直接求出其解。这自然导致递归过程的产生。分治与递归像一对孪生兄弟,经常同时应用在算法设计之中,并由此产生许多高效算法。

核心思想如图
图解

定义整个分支法的伪代码。进行递归调用,知道最终每一个子序列都排列好,然后进行MERGE合并。就好比是把一堆牌,分摊成等分的两堆,然后分成四堆,一直到最后,每一堆只剩下一张牌,不能再分。这时候就可以进行合并,采用的伪代码如上所述。

分治法
合并的过程

结束语

不得不说这个东西还真是厉害,也不愧是我学长说一个寒假也就看完一两章的神书。这第一章具体的算法,就让我花了整整半天时间去琢磨,现在脑子还是有点晕乎乎的。加油 继续继续~~~

个人宣言

知识传递力量,技术无国界,文化改变生活!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 算法和数据结构 [TOC] 算法 函数的增长 渐近记号 用来描述算法渐近运行时间的记号,根据定义域为自然数集$N=...
    wxainn阅读 1,054评论 0 0
  • 一. 写在前面 要学习算法,“排序”是一个回避不了的重要话题,在分析完并查集算法和常用数据结构之后,今天我们终于可...
    Leesper阅读 2,516评论 0 40
  • 当年快播关闭之初被曝光出腾讯举报快播,引发了热议,我们简单回顾分析一下当年为什么会举报快播。 当年视频市场一片火爆...
    大头超人x阅读 928评论 0 0
  • 第一次和女儿自由出行,领略厦门的美食和美景,悠闲自在,虽然有时走路会比较累,但是一天下来感觉很充实,很爽!以后会多...
    jesse飘阅读 158评论 0 0
  • 他又去买了一瓶没有喝过的饮料,他又换了一个新女友,他又去了一个新的地方。。。我们的耳边,仿佛总有这样的人,不停在尝...
    长亭微雨阅读 278评论 0 0