分析下列算法的时间复杂度。麻烦也告诉一下怎样算的,谢谢!
intrec(intn){if(n<=1)return1;elsereturnrec(n-1)*rec(n-1);}...
int rec(int n)
{
if(n<=1)
return 1;
else
return rec(n-1)*rec(n-1);
} 展开
{
if(n<=1)
return 1;
else
return rec(n-1)*rec(n-1);
} 展开
1个回答
展开全部
每当调用这个函数时会产生2个递归分支,所以时间复杂度是O(2^n)。
n==1时,调用1次rec(1),
n==2时,调用1次rec(2),2次rec(1),
n==3时,调用1次rec(3),2次rec(2),4次rec(1),
以此类推,总的调用次数为2^0+2^1+2^2+...+2^(n-1)=2^n-1,
因为函数内不存在循环,T(n)=(2^n-1)*1=2^n-1,
存在正的常数c,n0使得对于任意n>=n0时有T(n)<=c*2^n,
所以这个时间复杂度是O(2^n)。
n==1时,调用1次rec(1),
n==2时,调用1次rec(2),2次rec(1),
n==3时,调用1次rec(3),2次rec(2),4次rec(1),
以此类推,总的调用次数为2^0+2^1+2^2+...+2^(n-1)=2^n-1,
因为函数内不存在循环,T(n)=(2^n-1)*1=2^n-1,
存在正的常数c,n0使得对于任意n>=n0时有T(n)<=c*2^n,
所以这个时间复杂度是O(2^n)。
Sievers分析仪
2024-12-30 广告
2024-12-30 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准...
点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询