复杂度分析之大O表示法。

2024-02-08 02:18

本文主要是介绍复杂度分析之大O表示法。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、概要。
好的程序设计表现出程序执行速度快,占用内存空间小的优点,分别对应时间复杂度和空间复杂度。
2、复杂度分类两种。
算法的时间复杂度是指算法需要消耗的时间资源。算法执行时间的增长率与f(n) 的增长率正相关,称作渐近时间复杂度(Asymptotic Time Complexity),简称时间复杂度。定义为T(n) = O(f(n)),称函数T(n)以f(n)为界或者称T(n)受限于f(n)。
算法的空间复杂度是指算法需要消耗的空间资源。其计算和表示方法与时间复杂度类似,一般都用复杂度的渐近性来表示。

常见的算法时间复杂度由小到大依次为:
O(1) 常数阶
O(logn) 对数阶
O(n) 线性阶
O(n*logn) 线性对数阶
O(n^2) 平方阶
O(n^k) K方阶
O(2^n) 指数阶
O(n!) 阶乘阶

其中,O(2^n) 和O(n!)为非多项式量级,NP(Non-Deterministic Polynomial,非确定多项式)问题,其复杂度计算机往往不能承受的。除此二者,都是多项式量级。
在这里插入图片描述
图表来源:https://www.bigocheatsheet.com

3、时间复杂度。
3.1辨识要素及示例。

int CalcSum(int n)
{int sum = 0;for (int i = 0; i < n; i++){sum += i;}return sum;
}

Demo求累加和,假设每条语句执行时间为time,容易算出来该函数运行时间为:T(n) = time+time+ntime2 = 2*(n+1)*time。用f(n)来表示代码的执行次数和数据规模的关系,即f(n)=2n+2。f(n)中的常数项对于整个公式的值的影响我们直接忽略,同样,我们也忽略系数。即得:f(n) = n;代入T(n) = O(f(n)),得:T(n) = O(n),线性阶。

①、只关注循环执行次数最多的一段代码;


int CalcSum(int n)
{int sum1 = 0;int sum2 = 0;for (int i = 0; i < n; i++){sum1 += i;}for (int j = 0; j < n * 2; j++){sum2 += j;}return sum1 + sum2;
}

容易看出来循环二比循环一的执行次数多,因此只需要关注循环二,得到T(n) = O(n);线性阶。
②、加法法则:总复杂度等于量级最大的那段代码的复杂度;

int CalcSum(int n)
{int sum1 = 0;int sum2 = 0;int sum3 = 0;for (int i = 0; i < 100; i++){sum1 += i;}for (int j = 0; j < n; j++){sum2 += j;}for (int i = 0; i < n; i++){for (int j = 0; j < n; j++){sum3 += j;}}return sum1 + sum2 + sum3;
}

容易得到循环一二三的时间复杂度分别为:O(1) (常数阶),O(n)(线性阶),O(n^2)(平方阶);则T(n) = O(1)+O(n)+O(n^2);按照加法原则,总复杂度等于量级最大的那段代码的复杂度。即T(n) = O(n^2),平方阶。
③、乘法法则:嵌套代码的复杂度等于嵌套内外代码复杂度的乘积。


int CalcSum(int n)
{int sum = 0;for (int i = 0; i < n; i++){for (int j = 0; j < n; j++){sum += j;}}return sum;
}

嵌套循环 = 外层内层。即T(n) = O(nn) = O(n^2),平方阶。
Ps:
对数阶:

int CalcSum(int n)
{int sum = 0;int i = 1;do{i = i * 2;sum += i;} while (i < n);return sum;
}

在while循环里面,每次都将 i 乘以 2翻倍,距离n越来越近。循环x次后,退出,也就是说2^x >=n。那么x = log2n(以2为底,n的对数)。这就是对数阶,时间复杂度为:T(n) = O(logn)。
线性对数阶:
将对数阶循环n遍,就是线性对数阶。即:T(n) = n*(O(logn)) = O(n*logn)。
3.2时间复杂度三种类别。
时间复杂度里细分起来又有最好、最坏、平均情况时间复杂度之分:
1、最好情况时间复杂度就是在最理想的情况下,执行这段代码的时间复杂度;
2、最坏情况时间复杂度就是在最糟糕的情况下,执行这段代码的时间复杂度;
3、平均情况时间复杂度顾名思义就是结合概率论分析从最好到最坏每种情况平均下来的加权平均时间复杂度。
在这里插入图片描述
图表来源:https://www.bigocheatsheet.com
4、空间复杂度。
空间复杂度比较常用的有:O(1)、O(n)、O(n²)。
4.1 S(n) = O(1).
不存在存储空间随变量变化情况。

void GetSpace(int n)
{vector<int> array;array.push_back(1);array.push_back(2);array.push_back(3);array.push_back(4);array.push_back(5);int sum = 0;for (auto it:array){sum += it;}
}

4.2 S(n) = O(n).
例程中,申请空间后,没有在申请其他空间。复杂度为:O(n)。

void GetSpace(int n)
{int* p = new int[n];int sum = 0;for (int i = 0; i <= n; ++i){sum += i;}
}

5、 总结
①、算法的速度并非指时间,不是以秒为单位;而是操作数的增速。从增量的角度度量的。
②、平时说算法的速度,指的是随着输入的增加,其运行时间将会以什么样的速度进行增加。
③、算法运行时间用大O表示法表示。
④、 O(㏒n)比O(n)快。当操作的元素规模差距越大,快的越明显。

这篇关于复杂度分析之大O表示法。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/689640

相关文章

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

锐捷和腾达哪个好? 两个品牌路由器对比分析

《锐捷和腾达哪个好?两个品牌路由器对比分析》在选择路由器时,Tenda和锐捷都是备受关注的品牌,各自有独特的产品特点和市场定位,选择哪个品牌的路由器更合适,实际上取决于你的具体需求和使用场景,我们从... 在选购路由器时,锐捷和腾达都是市场上备受关注的品牌,但它们的定位和特点却有所不同。锐捷更偏向企业级和专

Spring中Bean有关NullPointerException异常的原因分析

《Spring中Bean有关NullPointerException异常的原因分析》在Spring中使用@Autowired注解注入的bean不能在静态上下文中访问,否则会导致NullPointerE... 目录Spring中Bean有关NullPointerException异常的原因问题描述解决方案总结

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

python-nmap实现python利用nmap进行扫描分析

《python-nmap实现python利用nmap进行扫描分析》Nmap是一个非常用的网络/端口扫描工具,如果想将nmap集成进你的工具里,可以使用python-nmap这个python库,它提供了... 目录前言python-nmap的基本使用PortScanner扫描PortScannerAsync异

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud