zoukankan      html  css  js  c++  java
  • 时间复杂度

      看看有几重for循环,只有一重则时间复杂度为O(n),二重则为O(n^2),依此类推,如果有二分则为O(logn),如二分查找,如果一个for循环套一个

    二分,那么时间复杂度则为O(nlogn)。

      常数阶O(1)、对数阶O(log2n)、线性阶O(n)、线性对数阶O(nlog2n)、平方阶O(n^2)、立方阶O(n^3)、k次方阶O(n^k)、指数阶O(2^n)
    (1)   for(i=1;i<=n;i++)
                for(j=1;j<=n;j++)
                     s++;                   //n*n次,当然是O(n^2)
    
    
    (2)   for(i=1;i<=n;i++)
                for(j=i;j<=n;j++)
                     s++;                  //(n+n-1+n-2+...+1)≈(n^2)/2,因为时间复杂度是不考虑系数的,所以也是O(n^2)
    
    
    (3)   for(i=1;i<=n;i++)
                for(j=1;j<=i;j++)
                     s++;                     //循环了(1+2+3+...+n)≈(n^2)/2,当然也是O(n^2)搜索
    
    
    (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)
  • 相关阅读:
    正则表达式复习 (?<=) (?=)
    HTML 30分钟入门教程
    C# 多线程详解
    C# List
    C# 枚举
    C# 线程数
    C# 泛型2
    C# 泛型
    C# 结构体
    不用Google Adsense的84个赚钱方法
  • 原文地址:https://www.cnblogs.com/yuyutianxia/p/3849470.html
Copyright © 2011-2022 走看看