时间复杂度

时间复杂度

一直对时间复杂度的概念不弄明白,今天就总结来作笔记学习吧学习

时间复杂度是总运算次数表达式中受n的变化影响最大的那一项(不含系数)spa

(1)   for(i=1;i<=n;i++)   //循环了n*n次,固然是O(n^2)
            for(j=1;j<=n;j++)
                 s++;
(2)   for(i=1;i<=n;i++)//循环了(n+n-1+n-2+...+1)≈(n^2)/2,由于时间复杂度是不考虑系数的,因此也是O(n^2)
            for(j=i;j<=n;j++)
                 s++;
(3)   for(i=1;i<=n;i++)//循环了(1+2+3+...+n)≈(n^2)/2,固然也是O(n^2)
            for(j=1;j<=i;j++)
                 s++;
(4)   i=1;k=0;
      while(i<=n-1){
           k+=10*i;
i++; }
//循环了
n-1≈n次,因此是O(n)
(5) for(i=1;i<=n;i++)
             for(j=1;j<=i;j++)
                 for(k=1;k<=j;k++)
                       x=x+1;
//
循环了(1^2+2^2+3^2+...+n^2)=n(n+1)(2n+1)/6(这个公式要记住哦)≈(n^3)/3,不考虑系数,天然是O(n^3)
另外,在时间复杂度中,log(2,n)(以2为底)与lg(n)(以10为底)是等价的,由于对数换底公式:
 
log(a,b)=log(c,b)/log(c,a)
因此,log(2,n)=log(2,10)*lg(n),忽略掉系数,两者固然是等价的

常见的时间复杂度
按数量级递增排列,常见的时间复杂度有:
常数阶O(1),  对数阶O(log2n),  线性阶O(n),  线性对数阶O(nlog2n),  平方阶O(n^2), 立方阶O(n^3),..., k次方阶O(n^k), 指数阶O(2^n) 。
其中,
1.O(n),O(n^2), 立方阶O(n^3),..., k次方阶O(n^k) 为多项式阶时间复杂度,分别称为一阶时间复杂度,二阶时间复杂度。。。。
2.O(2^n),指数阶时间复杂度,该种不实用
3.对数阶O(log2n),   线性对数阶O(nlog2n),除了常数阶之外,该种效率最高


例:

int count = 1;code

while (count < n)class

{    效率

count = count * 2; /* 时间复杂度为O(1)的程序步骤序列 */循环

}程序

 

 

因为每次count乘以2以后,就距离n更近了一分。总结

也就是说,有多少个2相乘后大于n,则会退出循环。时间

由2x=n获得x=log2n。因此这个循环的时间复杂度为O(logn)。while

相关文章
相关标签/搜索