三种方法求递归算法的时间复杂度(递推,master定理,递归树)

三种方法:

  • 递推方法求递归算法的时间复杂性
  • Master定理方法求递归算法时间复杂性
  • 递归树求解递归方程

1.递推方法求递归算法的时间复杂度

我们先来看一个经典的案例,汉诺塔问题

汉诺塔(Hanoi Tower),又称河内塔,源于印度一个古老传说。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,任何时候,在小圆盘上都不能放大圆盘,且在三根柱子之间一次只能移动一个圆盘。问应该如何操作?

相信大家都见过这个问题,我就不多加赘述了,没有看过的可以可以查看一下下面的资料

汉诺塔问题

我们给出伪代码

算法 Hanoi (,,n) // n个盘子到
if n = 1 then move (,) // 1个盘子到
else Hanoi (,,n − 1)
move (,)
Hanoi (,,n − 1)

时间复杂度:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第1张图片

我们使用递推法求事件复杂度:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第2张图片

 这时候我们发现,汉诺塔问题的时间复杂度是指数级别的。

2.Master定理方法求递归算法时间复杂性

在常见的分治算法中,我们通常设计为递归算法。

关于分治算法,可以查看下面这个博客:

分治算法

其事件复杂度的递归定义通常有如下形式:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第3张图片

 使用master定理可以快速求解该方程

这里要求a >= 1, b > 1为整数,f(n)是正函数

方法如下:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第4张图片

 我们先来分析三个规则,规则1对应大于,规则2对应等于,规则3对应小于

规则1举例:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第5张图片

规则2举例:

我们取计算机算法设计与分析第五版第二章合并算法来分析

pdf地址:http://jxz1.j9p.com/pc/jsjsfyfx5.pdf

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第6张图片 三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第7张图片

规则3举例:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第8张图片

 这个例子很简单,为了更深度的理解规则3,我们在举一个例子

解法: 

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第9张图片 当看到我们老师给出这个解法的时候,我很纳闷,为什么ε要取0.2

我搜索了很多资料

证明方法

20个训练题目(附答案)

看完这些之后,我悟了,原来是我没有明白O、Ω、θ三个符号的意义,这里给出定义

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第10张图片

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第11张图片 三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第12张图片 

 而我们规则3的定义是

下界Ω

按照我的理解就是只要f(n)的阶层比高即可

那么我们取0.1也是可以的

但是如果我们取0.3就不可以了,因为当取0.3的时候,n的指数就大于1了,当n无穷大时,取极限,它的数值大于nlogn,所以n的指数只能小于1

再看一个例子:

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第13张图片

3.递归树求解递归方程

递归树的规则为:

  (1) 每层的节点为T(n) = kT(n / m) + f(n)中的f(n)在当前的n/m下的值;

  (2) 每个节点的分支数为k;

  (3)每层的右侧标出当前层中所有节点的和。

举一个例子:

 三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第14张图片

再举个例子:

  T(n) = T(n/3) + T(2n/3) + n

  其递归树如下图所示:

  

三种方法求递归算法的时间复杂度(递推,master定理,递归树)_第15张图片

  可见每层的值都为n,从根到叶节点的最长路径是:

  因为最后递归的停止是在(2/3)kn == 1.则

  于是

   即T(n) = O(nlogn) 

文章中图片来源:张舒老师的课件(感谢!!!)

你可能感兴趣的:(算法,算法,线性代数)