美文网首页
时间复杂度

时间复杂度

作者: FRAJ | 来源:发表于2019-05-22 14:24 被阅读0次

常见的五种时间复杂度:

  • O(1):常数复杂度,最快的算法

取数组第1000000个元素
字典和集合的存取都是O(1)
数组的存取是O(1)

  • O(logN):对数复杂度

假设有一个有序数组,以二分法查找

  • O(n):线性复杂度

假设有一个数组,以遍历的方式在其中查找元素

  • O(nlogN):求两个数组的交集,其中一个是有序数组

A数组每一个元素都要在B数组中进行查找操作
每次查找如果使用二分法则复杂度是logN。

  • O(n^2):平方复杂度

求两个无序数组的交集


  1. 对于一个循环,假设循环体的时间复杂度为O(n),循环次数为m,则这个循环的时间复杂度为O(n*m)。
void aFunc(int n){
  for (int i = 0; i<n; i++){   //循环次数为n
    printf("Hello world!\n");  //循环体时间复杂度为O(1)
  }
}

此时时间复杂度为O(n*1),即O(n)。

  1. 对于多个循环,假设循环体的时间复杂度为O(n),各个循环次数分别是a,b,c ...,则这个训话的时间复杂度为O(n*a*b*c...)。分析的时候应该有里向外分析这些循环。
void aFunc(int n){
  for (int i = 0; i<n; i++){     //循环次数为n
    for (int j = 0; j<n; j++){   //循环次数为n
      printf("Hello world!\n");  //循环体时间复杂度为O(1)
    }
  }
}

此时时间复杂度为O(n*n*1),即O(n^2)。

  1. 对于顺序执行的语句或者算法,总的时间复杂度等于其中最大的时间复杂度。
void aFunc(int n){
//第一部分时间复杂度为O(n^2)
  for (int i = 0; i < n; i++){     //循环次数为n
    for (int j = 0; j < n; j++){   //循环次数为n
      printf("Hello world!\n");  //循环体时间复杂度为O(1)
    }
  }
//第二部分时间复杂度为O(n)
 for (int j = 0; j<n; j++){   //循环次数为n
    printf("Hello world!\n");  //循环体时间复杂度为O(1)
  }
}

此时时间复杂度为max(O(n^2) ,O(n),即O(n^2)。

  1. 对于条件判断语句,总的时间复杂度等于其中时间复杂度最大的路径的时间复杂度。
void aFunc(int n){
  if (n >= 0){
    //第一条路径时间复杂度为O(n^2)
    for (int i = 0; i < n; i++){    
      for (int j = 0; j < n; j++){  
        printf("输入数据大于等于零\n");  
      }
    }
  }else{
   //第二条路径时间复杂度为O(n)
   for (int j = 0; j < n; j++){  
      printf("输入数据小于零\n"); 
    }
  }
}

此时时间复杂度为max(O(n^2), O(n)),即O(n^2)。

时间复杂度分析的基本策略是:从内向外分析,从最深层开始分析。如果遇到函数调用,要深入函数进行分析。

相关文章

  • 时间复杂度(下)

    时间复杂度知识点 最好时间复杂度 最坏时间复杂度 平均情况复杂度 均摊时间复杂度

  • day02 四种时间复杂度分析方法

    一、时间复杂度有哪几种? 最好时间复杂度 最坏时间复杂度 平均时间复杂度(概率) 均摊时间复杂度(特殊的平均时间复...

  • 数据结构与算法之美笔记——复杂度分析(下)

    摘要: 时间复杂度还可分为四种,分别是「最好时间复杂度」、「最坏时间复杂度」、「平均时间复杂度」和「均摊时间复杂度...

  • 算法学习笔记-浅析时间复杂度

    四种情况的维度: 最好情况时间复杂度 最坏情况时间复杂度 平均情况时间复杂度 均摊时间复杂度 最好时间复杂度 在最...

  • sort_algorithm

    排序方法 时间复杂度(平均) 时间复杂度(最坏) 时间复杂度(最好) 空间复杂度 稳定性 复...

  • 归并排序图解

    平均时间复杂度:O(nlogn) 最佳时间复杂度:O(n) 最差时间复杂度:O(nlogn) 空间复杂度:O(n)...

  • 时间复杂度和空间复杂度笔记

    复杂度分析笔记 复杂度主要分为时间和空间复杂度 时间复杂度:算法(程序)执行的时间变化趋势 空间复杂度:算法(程序...

  • 归并排序 by Python

    最好时间复杂度:O(n*logn)最坏时间复杂度:O(n*logn)平均时间复杂度:O(n*logn)空间复杂度:...

  • day09-冒泡排序+优化

    排序算法(SortAlgorithm) 算法时间复杂度总结: 排序方法时间复杂度(平均)时间复杂度(最坏)时间复杂...

  • 时间复杂度和空间复杂度

    时间复杂度 如何理解算法时间复杂度 1.时间复杂度,表示形式为Big O notation 时间复杂度也可以理解为...

网友评论

      本文标题:时间复杂度

      本文链接:https://www.haomeiwen.com/subject/kcnyzqtx.html