算法的时间复杂度 递推

算法的时间复杂度  递推

1.

 

NOIP 2013 提高组 初赛

7.斐波那契数列的定义如下:F1 = 1, F2 = 1, Fn =Fn–1 + Fn–2 (n ≥ 3)。如果用下面的函数计算斐波那契数列的第 n 项,则其时间复杂度为( )

int F(int n)

{

       if(n<=2)

              return 1;

       else

              return F(n-1)+F(n-2);

}

A. O(1)          B.O(n)          C. O(n2)      D. O(Fn)

 

2.

 

NOIP 2015 提高组 初赛

10.设某算法的计算时间表示为递推关系式T(n)= T(n -1) + n(n 为正整数)及T(0) = 1,则该算法的时间复杂度为(       )

A.O(log n)         B.O(nlog n)      C.O(n)               D.O(n2)

 

 

 

3.

 

NOIP 2016 提高组 初赛

 

 

 

 

 

答案:

1.D

2.D

3.C

 

详解:

 

2.

 

T(n)=T(n-1)+n                             (1)

T(n-1)=T(n-2)+n-1                       (2)

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

T(n-3)=T(n-4)+n-3                       (4)

……

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

T(2)=T(1)+2                                 (n-1)

T(1)=T(0)+1                                 (n)

 

将(n)式带回(n-1) 式,将(n-1)式带回(n-2) 式,将式子依次带回,最后带回(4) 式,(3) 式,(2) 式,(1) 式。带入式子结果如下:

T(n)=T(0)+1+2+3+……+n-3+n-2+n-1+n

计算结果如下:

T(n)=1+1+2+3+……+n-3+n-2+n-1+n

T(n)=1+(1+n)*n/2

故算法的时间复杂度为

O(n2)

 

3.

 

 

  • 15
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
快速排序的最坏时间复杂度为O(n^2),最好时间复杂度为O(nlogn)。 快速排序的时间复杂度主要取决于分区点的选择,最坏情况下,每次选择的分区点都是当前序列中的最大(或最小)值,导致分区不平衡,时间复杂度退化为O(n^2)。最好情况下,每次选择的分区点都是当前序列的中位数,导致分区比较平衡,时间复杂度为O(nlogn)。 具体推导过程如下: 首先,快速排序的基本思想是选取一个“基准值”(pivot),将序列中小于基准值的元素放在基准值的左侧,大于基准值的元素放在基准值的右侧,然后对左右两个子序列分别进行递归排序。 在每一次递归过程中,选择基准值的方式会对时间复杂度产生影响。一般情况下,可以采用以下三种方式: 1. 选择第一个元素作为基准值; 2. 选择最后一个元素作为基准值; 3. 选择随机元素作为基准值。 为了方便,我们假设每次选择第一个元素作为基准值。然后对于一个长度为n的序列,我们可以将其分为左右两个子序列S1和S2,其中S1中的元素都小于等于基准值,S2中的元素都大于基准值。具体过程如下: 1. 初始化i=1,j=n,将第一个元素作为基准值pivot; 2. 从右往左扫描序列,找到第一个小于基准值的元素S[j],将其与S[i]交换; 3. 从左往右扫描序列,找到第一个大于基准值的元素S[i],将其与S[j]交换; 4. 重复执行步骤2和3,直到i=j为止; 5. 递归对S1和S2进行排序。 在最好情况下,每次选择的基准值都正好将序列分为长度相等的两个子序列,即S1和S2的长度均为n/2。此时,快速排序的时间复杂度可以写成如下递推公式: T(n) = 2T(n/2) + O(n) 其中,第一项2T(n/2)表示对S1和S2分别进行递归排序的时间复杂度,第二项O(n)表示分区过程的时间复杂度。根据主定理,可以得到T(n) = O(nlogn)。 在最坏情况下,每次选择的基准值都是当前序列中的最大或最小值,导致S1或S2的长度为0,另一侧的长度为n-1。此时,快速排序的时间复杂度可以写成如下递推公式: T(n) = T(n-1) + O(n) 其中,第一项T(n-1)表示对长度为n-1的子序列进行递归排序的时间复杂度,第二项O(n)表示分区过程的时间复杂度。根据递推公式,可以得到T(n) = O(n^2)。 因此,快速排序的时间复杂度在最好情况下为O(nlogn),最坏情况下为O(n^2)。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值