算法空间复杂度详解

news2024/12/22 19:42:04

 

如果您觉得文章不错,期待你的一键三连哦,你的鼓励是我创作的动力之源,让我们一起加油,一起奔跑,让我们顶峰相见!!!

前言

避免在处理大规模问题时出现效率低下,耗费较多资源,所以引入了算法复杂度,算法复杂度可以来衡量算法的效率和算法的可行性,可以帮助选择出最优的算法来解决问题;

空间复杂度的概念

空间复杂度也是一个数学表达式,是对一个算法在运行过程中额外临时占用存储空间大小的量度 。
空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。空间复杂度计算规则基本跟实践复杂度类似,也使用大O渐进表示法。
注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显式申请的额外空间来确定

实例(含分析)

所需知识:大O渐近表示法,如有不懂的请到前一篇文章《时间复杂度》内学习

例一: 计算BubbleSort的空间复杂度?

 分析:

该算法是一个排序的算法,所计算的空间复杂度的大小是为了排序所额外开辟的空间;

结果:

根据上面的分析,该算法开辟的空间有3个,是常数个,根据大O渐近表示法,

BubbleSort的空间复杂度为  O(1) 

例二:计算Fibonacci的空间复杂度?返回斐波那契数列的前n项

 

 分析:

 结果:

根据上面的分析,该算法开辟的空间有n+2个,根据大O渐近表示法

Fibonacci的空间复杂度为: O(N)

例三:

 分析:

结果:每次调用开辟常数个空间,即O(1) ;会调用N次;会开辟N个O(1), 所以根据大O渐近表示法,

阶乘递归Fac的空间复杂度为 :O(N)  ;

例四    计算斐波那契递归Fib的空间复杂度?

分析:首先理解一下时间和空间

时间:是一去不复返的,用了就没了,是累积的;

空间:计算机内给某个变量或则函数开辟的空间,用完之后是会还给操作系统的,然后会被分配给其他人使用;是可以重复利用的:

普通函数是一次调用,而递归是多次调用;

当计算Fib(N)时,并不是同时调用Fib(N-1)  与Fib(N-2)

而是会像上图红色的箭头所示调用;这里调用了N-1次,开辟了N-1次常数大小的空间,空间复杂度为:O(N);当调用完后,又会像上图蓝色箭头所示返回,返回过后,所开辟的栈帧就销毁了,例如上面的Fib(2)的值返回后,为Fib(2)所开辟的空间油还给操作系统了,还给操作系统的空间会继续调用其他的Fib,知道算法结束;

结果:

根据上述的分析:整个算法在执行的过程中,最大值开辟了N-2个常数大小的空间,而为该算法开辟大的这些空间,会重复利用,来实现该算法,所以该算法的空间复杂度为:O(N)

栈帧的复用的理解

如下代码及结果

void Func1()
{
	int a = 10;
	printf("%p\n",&a);
}
void Func2()
{
	int b = 20;
	printf("%p\n",&b);
}


int main()
{
	Func1();
	Func2();


	return 0;
}

 分析:


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

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

相关文章

STM32 Flash学习(一)

STM32 FLASH简介 不同型号的STM32,其Flash容量也不同。 MiniSTM32开发板选择的STM32F103RCT6的FLASH容量为256K字节,属于大容量产品。 STM32的闪存模块由:主存储器、信息块和闪存存储器接口寄存器等3部分组成。 主存储器,该部分…

服务器被爬虫恶意攻击怎么办?

在有预算的情况可以采购第三方服务防火墙,没钱就使用开源的WAF进行防护。 # WAF防火墙的基本防护原理 WAF(Web 应用防火墙)可以使用多种技术来防止恶意爬虫攻击,例如: 1. 黑名单:WAF 可以使用黑名单技术来…

会点C++还需要再学Python吗?

提到的C、数据结构与算法、操作系统、计算机网络和数据库技术等确实是计算机科学中非常重要的基础知识领域,对于软件开发和计算机工程师来说,它们是必备的核心知识。掌握这些知识对于开发高性能、可靠和安全的应用程序非常重要。Python作为一种脚本语言&…

Spring Cloud+Spring Boot+Mybatis+uniapp+前后端分离实现知识付费平台免费搭建

Java版知识付费-轻松拥有知识付费平台 多种直播形式,全面满足直播场景需求 公开课、小班课、独立直播间等类型,满足讲师个性化直播场景需求;低延迟、双向视频,亲密互动,无论是互动、答疑,还是打赏、带货、…

【C++初阶】介绍stack_queue及OJ题

介绍stack_queue及OJ题 前言一、简单了解1、stack2、queue 二、OJ题(前三个栈,第四、五个队列)1、最小栈(1)题目描述(2)解题思路(3)解题代码 2、栈的压入、弹出序列&…

【C#】并行编程实战:异步流

本来这章该讲的是 ASP .NET Core 中的 IIS 和 Kestrel ,但是我看了下这个是给服务器用的。而我只是个 Unity 客户端程序,对于服务器的了解趋近于零。 鉴于我对服务器知识和需求的匮乏,这里就不讲原书(大部分)内容了。本…

基于RPA的自动化流程治理方案探索及应用实践

编者荐语: 随着企业数字化转型进程加快,信息系统大量上线,但流程运营管理问题逐渐显现出来。为提升企业流程运营能力,亚信科技联合某省运营商推出智能化流程治理运营模式,尝试基于RPA(机器人流程自动化&am…

IRIS搭建docker

之前把web实现了docker,开发或测试环境可能需要开发自己搭数据库,为了方便使用,把数据库也做一个docker。 由于原生的CentOS我还有改yum仓库,所以这次从之前lis搞的改好yum的镜像开始(从改好yum的lisnew的镜像创建lis…

SaaS到底是什么,如何做?这份笔记讲明白了

阅读本篇文章,您将可以了解:1、什么是SaaS;2、SaaS的商业模式;3、SaaS的技术架构;4、国内比较好的SaaS平台。 一、什么是SaaS SaaS即软件即服务(Software as a Service),是一种通过…

【数据结构】AVL树/红黑树

目录 1.AVL树(高度平衡二叉搜索树) 10.1.基本概念 10.2.实现 10.2.1.AVL树节点的定义 10.2.2.AVL树的插入 10.2.3.AVL树的旋转 1.新节点插入较高左子树的左侧---左左:右单旋 2.新节点插入较高右子树的右侧---右右:左单旋 3.新节点…

Python Flask构建微信小程序订餐系统 (十二)

🔥 创建切换商品分类状态的JS文件 🔥 ; var food_act_ops={init:function(){this.eventBind();},eventBind:function(){//表示作用域var that = this;$(".wrap_search select[name=status]").change(function(){$(".wrap_search").submit();});$(&qu…

对ai绘画二次元生成器你有多少了解?

在一个小镇上,有一位年轻的艺术家名叫艾米莉。她是个富有创意的女孩,总是追求着新奇和美妙的艺术体验。然而,她最近遇到了一些创作上的障碍,感觉自己的绘画已经陷入了瓶颈。在艾米莉寻找灵感的过程中,她听说了神秘的ai…

SQL语句(三十二)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、SQL语句类型 二、数据库操作 ​三、数据表操作 1. 数据类型 2. 查看 3. 创建 4. 删除 5. 更改 5.1 表 5.2 列 四、数据操作 4.1 增 4.2 删 4.3 改 4.4 查…

13.5.4 【Linux】常用模块简介

登陆所需要的PAM流程: 上面这个表格当中使用到非常多的 PAM 模块,每个模块的功能都不太相同,详细的模块情报可以在你的系统中找到: /etc/pam.d/*:每个程序个别的 PAM 配置文件; /lib64/security/*&#x…

网络:HCIA 1

1. 通信系统的组成: 终端设备:电脑 中间设备:交换机、路由器、防火墙。 传输介质:网线(双绞线)传输距离一般为100米,传输的是电信号。 光纤传输的是光信号。 光纤接口类型,方形接口…

前端(九)——探索微信小程序、Vue、React和Uniapp生命周期

🙂博主:小猫娃来啦 🙂文章核心:探索微信小程序、Vue、React和Uniapp生命周期 文章目录 微信小程序、Vue、React和Uniapp的基本定义和应用领域微信小程序生命周期生命周期概述页面生命周期应用生命周期组件和API的生命周期钩子 Vu…

看完这篇,别再说不会Spring 分库分表了

多数据源,读写分离,分库分表,基本上已经是现在任何一个项目的基本配置了,在之前的文章Spring多数据源实现https://blog.csdn.net/wangerrong/article/details/131910740 里讲了多数据源的实现,其实已经包含了读写分离…

广东省《5A物理抗菌纺织品》团体标准颁布

近日,经广东省标准化协会批准发布由广东人仁康科技有限公司主导制定的《5A物理抗菌纺织品》(T/GDBX 073—2023)团体标准,于2023年7月21日发布并实施。 根据标准制修订工作流程,该项标准2022年由人仁康和广检集团组织起…

【【51单片机AD/DA的分析】】

51单片机AD/DA的分析 看似单片机实验,其实是要学好数电 模数转换 与 数模转换 运算放大器 DA的转换就是利用运算放大器实现的 输出电压v0-(D7~D0)/256 x (VrefxRfb)/R D7~D0 就是我们控制的按键看输入多少 然后再划分256份 Vref是我们设置的一个基准电压 PWM 这种…

若依分离版——解决配置双数据源oracle,mysql分页错误问题

1. 按照若依的手册配置双数据源mysql,oracle 2. 在service指定 数据源 DataSource(value DataSourceType.MASTER) 或者DataSource(value DataSourceType.SLAVE) Service public class SysPostServiceImpl implements ISysPostService {/*** 查询岗位信息集合* …