算法复杂度分为时间复杂度和空间复杂度。

其作用:

时间复杂度是指执行算法所需要的计算工作量;

而空间复杂度是指执行这个算法所需要的内存空间。

(算法的复杂性体现在运行该算法时的计算机所需资源的多少上,计算机资源最重要的是时间和空间(即寄存器)资源,因此复杂度分为时间和空间复杂度)。

简单来说,时间复杂度指的是语句执行次数,空间复杂度指的是算法所占的存储空间

时间复杂度

计算时间复杂度的方法:

用常数1代替运行时间中的所有加法常数

修改后的运行次数函数中,只保留最高阶项

去除最高阶项的系数

按数量级递增排列,常见的时间复杂度有:

常数阶O(1),对数阶O(log2n),线性阶O(n),

线性对数阶O(nlog2n),平方阶O(n^2),立方阶O(n^3),…,

k次方阶O(n^k),指数阶O(2^n)。

随着问题规模n的不断增大,上述时间复杂度不断增大,算法的执行效率越低。

举个栗子:

sum = n*(n+1)/2; //时间复杂度O(1)

for(int i = 0; i < n; i++){

printf("%d ",i);

}

//时间复杂度O(n)

for(int i = 0; i < n; i++){

for(int j = 0; j < n; j++){

printf("%d ",i);

}

}

//时间复杂度O(n^2)

for(int i = 0; i < n; i++){

for(int j = i; j < n; j++){

printf("%d ",i);

}

}

//运行次数为(1+n)*n/2

//时间复杂度O(n^2)

int i = 0, n = 100;

while(i < n){

i = i * 2;

}

//设执行次数为x. 2^x = n 即x = log2n

//时间复杂度O(log2n)

最坏时间复杂度和平均时间复杂度

最坏情况下的时间复杂度称最坏时间复杂度。一般不特别说明,讨论的时间复杂度均是最坏情况下的时间复杂度。

这样做的原因是:最坏情况下的时间复杂度是算法在任何输入实例上运行时间的上界,这就保证了算法的运行时间不会比任何更长。

平均时间复杂度是指所有可能的输入实例均以等概率出现的情况下,算法的期望运行时间。设每种情况的出现的概率为pi,平均时间复杂度则为sum(pi*f(n))

常用排序算法的时间复杂度

算法

最差时间分析

平均时间复杂度

稳定度

空间复杂度冒泡排序

O(n2)

O(n2)

稳定

O(1)

快速排序

O(n2)

O(n*log2n)

不稳定

O(log2n)~O(n)

选择排序

O(n2)

O(n2)

稳定

O(1)

二叉树排序

O(n2)

O(n*log2n)

不稳定

O(n)

插入排序

O(n2)

O(n2)

稳定

O(1)

堆排序

O(n*log2n)

O(n*log2n)

不稳定

O(1)

希尔排序

O

O

不稳定

O(1)

空间复杂度

空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度,记做S(n)=O(f(n))。

对于一个算法来说,空间复杂度和时间复杂度往往是相互影响的。当追求一个较好的时间复杂度时,可能会使空间复杂度的性能变差,即可能导致占用较多的存储空间;反之,当追求一个较好的空间复杂度时,可能会使时间复杂度的性能变差,即可能导致占用较长的运行时间。

有时我们可以用空间来换取时间以达到目的。

本作品采用《CC 协议》,转载必须注明作者和本文链接

php快速排序空间复杂度,PHP 算法基础----时间复杂度和空间复杂度(转载)相关推荐

  1. [算法基础]--时间复杂度和空间复杂度

    感谢原文作者:https://blog.csdn.net/zolalad/article/details/11848739 算法的时间复杂度和空间复杂度-总结 通常,对于一个给定的算法,我们要做 两项 ...

  2. a*算法的时间复杂度_算法基础——时间复杂度amp;空间复杂度

    关注.星标公众号,学点计算机知识. 整理:persistenceBin 今天来跟大家继续分享一下数据结构的基础知识--算法效率的度量:时间复杂度和空间复杂度.首先来跟大家分享一下在电影<复仇者联 ...

  3. 【计算机基础】 经常使用的排序算法的时间复杂度和空间复杂度

    经常使用的排序算法的时间复杂度和空间复杂度 排序法 最差时间分析 平均时间复杂度 稳定度 空间复杂度 冒泡排序 O(n2) O(n2) 稳定 O(1) 高速排序 O(n2) O(n*log2n) 不稳 ...

  4. 算法的时间复杂度和空间复杂度评估

    通常,对于一个给定的算法,我们要做 两项分析.第一是从数学上证明算法的正确性,这一步主要用到形式化证明的方法及相关推理模式,如循环不变式.数学归纳法等.而在证明算法是正确的基础上,第二部就是分析算法的 ...

  5. 计算算法的时间复杂度和空间复杂度

    算法的时间复杂度和空间复杂度-总结 通常,对于一个给定的算法,我们要做 两项分析.第一是从数学上证明算法的正确性,这一步主要用到形式化证明的方法及相关推理模式,如循环不变式.数学归纳法等.而在证明算法 ...

  6. 常用的排序算法的时间复杂度和空间复杂度

    常用的排序算法的时间复杂度和空间复杂度                                           1.时间复杂度 (1)时间频度 一个算法执行所耗费的时间,从理论上是不能算出 ...

  7. 常用的排序算法的时间复杂度和空间复杂度 .

    常用的排序算法的时间复杂度和空间复杂度 排序法 最差时间分析 平均时间复杂度 稳定度 空间复杂度 冒泡排序 O(n2) O(n2) 稳定 O(1) 快速排序 O(n2) O(n*log2n) 不稳定 ...

  8. 各种常用排序算法的时间复杂度和空间复杂度

    https://blog.csdn.net/jiajing_guo/article/details/69388331 一.常用排序算法的时间复杂度和空间复杂度表格 二.特点 1.归并排序: (1)n大 ...

  9. 【数据结构入门】算法的时间复杂度和空间复杂度详解

    文章目录 (1)算法效率 (2)时间复杂度的计算 1)什么是时间复杂度 2)大O渐进表示法(估算) 3)时间复杂度计算实例 4)总结 5)一些思考 (3)空间复杂度的计算 (4)常见复杂度对比 本篇前 ...

  10. 【数据结构与算法 10】算法的时间复杂度和空间复杂度

    最近在研究数据结构与算法,在B站中找到了小甲鱼的<数据结构与算法课程>,挺有意思的! 尚硅谷Java数据结构与java算法,韩顺平数据结构与算法 对于一个算法来说,分析有两步,第一是从数学 ...

最新文章

  1. python十五:函数作用域-函数即变量
  2. 200米外遥测心跳定身份,五角大楼全新黑科技,人脸伪装也没用
  3. Java 重入锁 ReentrantLock 原理分析
  4. php 实体转html,PHP 转HTML标签为实体, 把实体html标签转为,过滤html标签 | 学步园...
  5. 【CSDN】Markdown 如何画分界线
  6. Struts2的通配符配置方式
  7. 二分法求非线性方程组Java_用C#编写二分法解一元非线性方程
  8. 对List集合中的对象进行按某个属性排序
  9. 国产操作系统往事:四十年激变,终再起风云
  10. 服务器客户端证书,使用服务器和客户端证书以及私钥创建SSLContext
  11. 爱奇艺视频怎么下载,如何将qsv格式转为mp4格式
  12. 教你将PDF文件旋转的方法
  13. 一家有两个孩子,已知至少有一个孩子是在星期二出生的男孩。问:两个孩子都是男孩的概率是多大?
  14. 宅家神器—epub阅读器
  15. Flutter面试总结(2022)
  16. 2021年最具影响力的七起网络安全事件
  17. Chess Tournament (巧用思维)
  18. 微信公众号发送小程序卡片_微信公众号将能够直接给用户推送小程序卡片,社交电商开始发力...
  19. 斐讯db2_斐讯P1刷armbian变身linux小型服务器
  20. 乳酪gi_Windows 8生产力:谁动了我的奶酪? 哦,是的。

热门文章

  1. ASP.NET MVC Links
  2. CentOS和Ubuntu哪个好?
  3. Vue.nextTick DOM 更新循环结束之后执行延迟回调
  4. 5.6 除法器的实现
  5. 【转载】WebService到底是什么?
  6. 服务器监控之 ping 监控
  7. 转:你真的懂iOS的autorelease吗?
  8. 架构师之路(2)---详解面向过程
  9. 【推荐】会被快速否决的9种求职者.
  10. 中文NER碎碎念—聊聊词汇增强与实体嵌套