南大算法设计与分析课程复习笔记(3)L3 - Recursion

一、递归方程

按照分治的思想,可以将一个递归的复杂度写成递归方程

一、解递归方程--猜然后证明

该方法又称为代入法,步骤如下:

1、猜解的形式

2、数学归纳法证明正确

例子:

我们假设有如下递归式:

我们猜其解为T(n)=O(nlgn),然后对递归式进行替换,得

 

特别注意:我们替换之后得出的结果必须严格符合猜想,上面的例子如果最后得出T(n)<=cnlgn+1,都说明我们猜错了,需要选择新的猜解式。

二、解递归方程--递归树解

感觉这种方法比较的麻烦,一般用代入法和下面的master定理来做

例子

对于递归方程式:

它的递归树如下:

三、master定理

 如果a>=1和b>1,假设有一个递归函数,递归式如下:

 则有如下3条:

 

posted @ 2018-03-24 13:38  番茄汁汁  阅读(337)  评论(0编辑  收藏  举报