算法的复杂度

文章目录

    • 一、算法的效率
        • 1、复杂度的概念
        • 2、复杂度的重要性
    • 二、时间复杂度
    • 三、空间复杂度
    • 四、大O的渐进表示发
    • 五、计算复杂度案例
        • 1、计算Func1函数的复杂度
        • 2、计算Fun2的时间复杂度
        • 3、计算Func3的时间复杂度
        • 4、计算Func4的时间复杂度
        • 5、计算strchr的时间复杂度
        • 6、计算Func5的时间复杂度
        • 7、计算BubbleSor的复杂度
        • 8、计算阶乘递归Fac的复杂度

一、算法的效率

在完成同一个算法题的过程中会有许多的方式和方法,最终完成的效果都是相同的都是正确的,但效率可能会有所差异。
就像在同一的地点出发要到到达另一个地点一样,到达地点的方式有飞机、火车、私家车……,但所用的时间不同,经济也不同。

1、复杂度的概念

算法在编写成可执⾏程序后,运⾏时需要耗费时间资源和空间(内存)资源 。因此衡量⼀个算法的好坏,⼀般 是从时间和空间两个维度来衡量的,即时间复杂度和空间复杂度。
时间复杂度主要衡量⼀个算法的运⾏快慢,⽽空间复杂度主要衡量⼀个算法运⾏所需要的额外空间。
在计算 机发展的早期,计算机的存储容量很⼩。所以对空间复杂度很是在乎。但是经过计算机⾏业的迅速发展,计 算机的存储容量已经达到了很⾼的程度。所以我们如今已经不需要再特别关注⼀个算法的空间复杂度。

2、复杂度的重要性

在我玩一些游戏的时候,有的游戏玩起来手机会很烫,有的游戏玩起来不烫,就离不开复杂度,我的手机在运行简单的算法很快就运行完了,但运行复杂的算法,要确保时间用的少就要启用全部功率,这样就会发烫。

二、时间复杂度

定义:在计算机科学中,算法的时间复杂度是⼀个函数式T(N),它定量描述了该算法的运⾏时间。时间复杂度是衡量程序的时间效率,那么为什么不去计算程序的运⾏时间呢?

  • 因为程序运⾏时间和编译环境和运⾏机器的配置都有关系,⽐如同⼀个算法程序,⽤⼀个⽼编译器进⾏编译和新编译器编译,在同样机器下运⾏时间不同。
  • 同⼀个算法程序,⽤⼀个⽼低配置机器和新⾼配置机器,运⾏时间也不同。
  • 并且时间只能程序写好后测试,不能写程序前通过理论思想计算评估。

所以在判断算法的时间赋值度时不 考虑执行算法的时间,只看执行多少次指令。

案例:

// 请计算⼀下Func1中++count语句总共执⾏了多少
次?
void Func1(int N)
{int count = 0;for (int i = 0; i < N ; ++ i)
{for (int j = 0; j < N ; ++ j){++count;}
} for (int k = 0; k < 2 * N ; ++ k){++count;}int M = 10;while (M--){++count;}
}

通过过观察:
Func1执行的基本操作次数:
T(N)=N2+ 2*N + 10

实际中我们计算时间复杂度时,计算的也不是程序的精确的执⾏次数,精确执⾏次数计算起来还是很⿇烦的(不同的⼀句程序代码,编译出的指令条数都是不⼀样的),计算出精确的执⾏次数意义也不⼤,因为我么计算时间复杂度只是想⽐较算法程序的增⻓量级,也就是当N不断变⼤时T(N)的差别,上⾯我们已经看到了当N不断变⼤时常数和低阶项对结果的影响很⼩,所以我们只需要计算程序能代表增⻓量级的⼤概执⾏次数,复杂度的表⽰通常使⽤⼤O的渐进表⽰法。

三、空间复杂度

空间复杂度也是⼀个数学表达式,是对⼀个算法在运⾏过程中因为算法的需要额外临时开辟的空间。
空间复杂度不是程序占⽤了多少bytes的空间,因为常规情况每个对象⼤⼩差异不会很⼤,所以空间复杂度算的是变量的个数。
空间复杂度计算规则基本跟实践复杂度类似,也使⽤⼤O渐进表⽰法。
注意:函数运⾏时所需要的栈空间(存储参数、局部变量、⼀些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运⾏时候显式申请的额外空间来确定
空间在现在的计算机发展中不是考虑的重点,但也要避免过度的浪费,浪费多了也会产生不必要的问题。

四、大O的渐进表示发

⼤O符号(Big O notation):是⽤于描述函数渐进⾏为的数学符号
推到大O渐进表示法的规则:

  • 1、时间复杂度函数式T(N)中,只保留最⾼阶项,去掉那些低阶项,因为当N不断变⼤时,
    低阶项对结果影响越来越⼩,当N⽆穷⼤时,就可以忽略不计了。
  • 2、如果最⾼阶项存在且不是1,则去除这个项⽬的常数系数,因为当N不断变⼤,这个系数
    对结果影响越来越⼩,当N⽆穷⼤时,就可以忽略不计了。
  • 3、T(N)中如果没有N相关的项⽬,只有常数项,⽤常数1取代所有加法常数。

最坏情况:任意输⼊规模的最⼤运⾏次数(上界)
平均情况:任意输⼊规模的期望运⾏次数
最好情况:任意输⼊规模的最⼩运⾏次数(下界)
⼤O的渐进表⽰法在实际中⼀般情况关注的是算法的上界,也就是最坏运⾏情况。

五、计算复杂度案例

1、计算Func1函数的复杂度
void Func1(int N)
{int count = 0;for (int i = 0; i < N; ++i){for (int j = 0; j < N; ++j){++count;}} for (int k = 0; k < 2 * N; ++k){++count;} int M = 10;while (M--){++count;}
}

时间复杂度:

把运行一次代码的省略比如count=0,这条代码.
保留对运行时间影响大的代码执行次数
第一个循环的执行次数是一个两次循环执行次数为NN
第二个循环为一层循环执行次数为2
N
第三次循环为10次
执行次数和为T(N)=N2+2*N+10
大O表示时间复杂度,把影响小的舍去取极限
O(N2)

空间复杂度:

Func1函数申请空间的大小,如int count = 0,申请了int类型的空间大小,int M=10,也是申请了int类型的空间.
在循环中也是使用这两个空间没有额外申请空间。
申请空间大小为常数
用大O表示空间复杂度为:
O(1)

2、计算Fun2的时间复杂度
void Func2(int N)
{int count = 0;for (int k = 0; k < 2 * N; ++k){++count;} int M = 10;while (M--){++count;} printf("%d\n", count);
}

时间复杂度:

代码运行的次数较大的为第一个循环运行次数为N*2
第二个循环运行10次
用大O表示时间复杂度,影响最大的为2*N,省略前面的系数项:
O(N)

3、计算Func3的时间复杂度

void Func3(int N, int M)
{int count = 0;for (int k = 0; k < M; ++k){++count;}for (int k = 0; k < N; ++k){++count;}printf("%d\n", count);
}

时间复杂度

有两个未知数,影响较的是两个循环
第一个循环运行M次
第二个循环运行N次
应为是未知数不确定谁大谁小都不省略
O(M+N)

4、计算Func4的时间复杂度
void Func4(int N)
{int count = 0;for (int k = 0; k < 100; ++k){++count;}printf("%d\n", count);
}

时间复杂度:

这里影响最大的是一个循环
循环运行的次数为100
是一个固定的常数
O(1)

5、计算strchr的时间复杂度
const char* strchr(const char* str, int character)
{const char* p_begin = str;while (*p_begin != character){if(*p_begin == '\0')return NULL;p_begin++;}return p_begin;
}

这个函数完成的功能是在一个数组中找一个字符在这个数组中的下标。
这里运行次数是不确定的
有可能一次就找到了F(N)=1
有可能在中间找到了F(N)=N/2
有可能最后才找到,或者找不到返回NULL,F(N)=N
大O是取最坏的情况:
时间复杂度为O(N)

6、计算Func5的时间复杂度
void func5(int n)
{int cnt = 1;while (cnt < n){cnt *= 2;}
}

这个运行次数是根据n的大小有关,但不是循环n次,应为在循环时循环变量会乘2,会很快的跳出循环,运行十次循环变量cnt的值就会来到1024
设循环次数为x,则2x=n
x=logn
所以时间复杂度为:O(longn)

7、计算BubbleSor的复杂度
void BubbleSort(int* a, int n)
{assert(a);for (size_t end = n; end > 0; --end){int exchange = 0;for (size_t i = 1; i < end; ++i){if (a[i - 1] > a[i]){Swap(&a[i - 1], &a[i]);exchange = 1;}} if(exchange == 0)break;}
}

这个函数完成的是冒泡升序排序
这里有一个循环,这个循环是个两层的循环嵌套
循环的次数是不确定的
最坏的情况为外层循坏运行n次
那么内层循环就要运行(n-1)+(n-2)+(n-3)+……+2+1+0
是一个等差数列,求和为:
在这里插入图片描述
时间复杂度为:O(N)

空间复杂度:

没有额外申请空间,申请的空间为常数
O(1)

8、计算阶乘递归Fac的复杂度
long long Fac(size_t N)
{if (0 == N)return 1;return Fac(N - 1) * N;
}

时间复杂度:

递归了N次
所以时间复杂度为:O(N)

空间复杂度:

每次递归都要申请空间
递归了N次申请了N次空间
空间复杂度为:O(N)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3227349.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

SuperCLUE最新测评发布,360智脑大模型稳居大模型第一梯队

7月9日&#xff0c;国内权威大模型评测机构SuperCLUE发布《中文大模型基准测评2024上半年报告》&#xff0c;360智脑大模型&#xff08;360gpt2-pro&#xff09;在SuperCLUE基准6月测评中&#xff0c;取得总分72分&#xff0c;超过GPT-3.5-Turbo-0125&#xff0c;位列国内大模型…

[GICv3] 3. 物理中断处理(Physical Interrupt Handling)

中断生命周期 ​​ 外设通过中断信号线生成中断&#xff0c;或者软件生成中断&#xff08;SGI&#xff09;。Distributor 和 ReDistributor 配合按照中断分组和中断优先级仲裁后将最高优先级的中断分发到 CPU interface。cpu interface 向中断发送到 PEPE 读取 IAR 寄存器&am…

Global Mapper:地理信息的温柔探索

引言 在这纷繁复杂的世界里&#xff0c;地理信息系统&#xff08;GIS&#xff09;如同一把利器&#xff0c;帮助我们剖析、理解和改造这个世界。而在众多GIS软件中&#xff0c;Global Mapper无疑是其中的佼佼者。作为一款功能全面且易于使用的GIS应用程序&#xff0c;Global M…

【服务器】在Linux查看运行的Python程序,并找到特定的Python程序

在Linux查看运行的Python程序并找到特定的Python程序 写在最前面1. 使用ps命令查看所有Python进程查看详细信息 2. 使用pgrep命令查找Python进程ID 3. 使用top或htop命令使用top命令使用htop命令 4. 使用lsof命令查找Python进程打开的文件 5. 使用nvidia-smi命令查看GPU使用情况…

InstructPix2Pix Learning to Follow Image Editing Instructions

InstructPix2Pix: Learning to Follow Image Editing Instructions TL; DR&#xff1a;核心是使用 GPT3 SD P2P 来机造指令编辑训练数据。 数据 本文要做的事情是教会模型根据指令来进行图像编辑。样例如下图所示&#xff0c;给定一张向日葵的图片和指令 “将向日葵换为玫…

zynq使用简单I/O对Flash进行读写测试

硬件环境&#xff1a;ALINX 7020 ZYNQ的QSPI Flash 控制器有以下三种模式&#xff1a;I/O 模式、线性地址模式&#xff0c;以及传统 SPI 模式。 I/O模式 操作特点&#xff1a;在I/O模式下&#xff0c;软件模拟去实现 Flash 器件的通信协议。软件需要将 Flash 命令和数据写到控…

【深度学习入门篇 ②】Pytorch完成线性回归!

&#x1f34a;嗨&#xff0c;大家好&#xff0c;我是小森( &#xfe61;ˆoˆ&#xfe61; )&#xff01; 易编橙终身成长社群创始团队嘉宾&#xff0c;橙似锦计划领衔成员、阿里云专家博主、腾讯云内容共创官、CSDN人工智能领域优质创作者 。 易编橙&#xff1a;一个帮助编程小…

二四、3d人脸构建

一、下载github项目3dmm_cnn-master https://github.com/anhttran/3dmm_cnn.git 一个使用深度神经网络从单个图像进行 3D 人脸建模的项目,端到端代码,可直接根据图像强度进行 3D 形状和纹理估计;使用回归的 3D 面部模型,从检测到的面部特征点估计头部姿势和表情。…

STM32中断学习记录

文章目录 NVICNVIC是什么NVIC寄存器NVIC 结构体NVIC 相关固件库函数 如何定义优先级中断编程外部中断 EXTIEXIT 外部中断/事件控制器EXIT的使用EXTI内部寄存器分析GPIO触发中断例程为什么中断后要清除中断标志位 SysTick的使用SysTick分析 NVIC NVIC是什么 待补充.........NVI…

Docker安装HomeAssistant

检查Docker服务是否正常运行&#xff0c;确保Docker正常运行。 systemctl status docker#输出---------------------- docker.service - Docker Application Container EngineLoaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)Activ…

旗晟智能巡检机器人:开启工业运维的智能化新篇章

在当今快速发展的工业领域&#xff0c;安全、效率和成本控制是企业运营的核心。旗晟科技以创新为驱动&#xff0c;推出了一站式的工业级智能巡检机器人数字化全景运维解决方案&#xff0c;为石油、天然气、化工、电力等高危行业提供了一个全新的运维模式。 一、面对挑战&#x…

人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解

大家好&#xff0c;我是微学AI,今天给大家分享一下人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解。 Sklearn&#xff08;Scikit-learn&#xff09;是一个基于Python的开源机器学习库&#xff0c;它提供了简单有效的数据挖掘和数据分析工具。Sklearn包含了…

动手学深度学习(Pytorch版)代码实践 -循环神经网络-57长短期记忆网络(LSTM)

57长短期记忆网络&#xff08;LSTM&#xff09; 1.LSTM原理 LSTM是专为解决标准RNN的长时依赖问题而设计的。标准RNN在训练过程中&#xff0c;随着时间步的增加&#xff0c;梯度可能会消失或爆炸&#xff0c;导致模型难以学习和记忆长时间间隔的信息。LSTM通过引入一组称为门…

碾压SOTA!最新视觉SLAM:渲染速度提升176倍,内存占用减少150%

视觉SLAM&#xff0c;一种结合了CV与机器人技术的先进方法。与激光SLAM相比&#xff0c;它成本低廉且信息量大&#xff0c;易于安装&#xff0c;拥有更优秀的场景识别能力&#xff0c;因此在自动驾驶等许多场景上都非常适用&#xff0c;是学术界与工业界共同关注的热门研究方向…

如何将heic格式转换jpg?四种将heic转换成jpg的方法!

如何将heic格式转换jpg&#xff1f;在现今的数字图像处理领域&#xff0c;Heic格式作为一种被吹捧的创新型图像格式&#xff0c;以其先进的压缩技术&#xff0c;迅速减小了图片文件的大小&#xff0c;然而&#xff0c;尽管其有许多优点&#xff0c;实际使用中Heic格式却带来了一…

RSA加密算法因N强度不足破解实例

已知如下RSA密文和公钥信息&#xff0c;要求解密得到明文。 ----------------------- ciphertext&#xff08;HEX&#xff09; 94808F954A8AF9B9 N&#xff08;HEX&#xff09; C6EAD137492B4631 e&#xff08;HEX&#xff09; 10001 ------------------------ 分析过…

【Linux】命令执行的判断依据:;,,||

在某些情况下&#xff0c;很多命令我想要一次输入去执行&#xff0c;而不想要分次执行时&#xff0c;该如何是好&#xff1f; 基本上有两个选择&#xff0c; 一个是通过shell脚本脚本去执行&#xff0c;一种则是通过下面的介绍来一次入多个命令。 1.cmd&#xff1a;cmd&#…

【Android】基于 LocationManager 原生实现定位打卡

目录 前言一、实现效果二、定位原理三、具体实现1. 获取权限2. 页面绘制3. 获取经纬度4. 方法调用5. 坐标转换6. 距离计算7. 完整代码 前言 最近公司有个新需求&#xff0c;想要用定位进行考勤打卡&#xff0c;在距离打卡地一定范围内才可以进行打卡。本文将借鉴 RxTool 的 Rx…

buuctf面具下的flag

细节: 这道题可能因为是vmdk的原因 导致在window上 7z无法得到全部的信息 所以最后解压要在linux系统上 解密网站 Brainfuck/Ook! Obfuscation/Encoding [splitbrain.org] 这道题010打开,可以发现里面隐藏了很多 binwalk解压 两个文件 vmdk可以直接 用7z解压 7z x flag.…

常用网络概念

&#x1f4d1;打牌 &#xff1a; da pai ge的个人主页 &#x1f324;️个人专栏 &#xff1a; da pai ge的博客专栏 ☁️宝剑锋从磨砺出&#xff0c;梅花香自苦寒来 ​​ 目录 了解组织 局域网技术 …