算法空间复杂度详解

简介: 算法空间复杂度详解

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

前言

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

空间复杂度的概念

空间复杂度也是一个数学表达式,是对一个算法在运行过程中额外临时占用存储空间大小的量度 。
空间复杂度不是程序占用了多少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;
}

分析:


目录
相关文章
|
2月前
|
机器学习/深度学习 缓存 算法
Python算法设计中的时间复杂度与空间复杂度,你真的理解对了吗?
【10月更文挑战第4天】在Python编程中,算法的设计与优化至关重要,尤其在数据处理、科学计算及机器学习领域。本文探讨了评估算法性能的核心指标——时间复杂度和空间复杂度。通过详细解释两者的概念,并提供快速排序和字符串反转的示例代码,帮助读者深入理解这些概念。同时,文章还讨论了如何在实际应用中平衡时间和空间复杂度,以实现最优性能。
76 6
|
4月前
|
机器学习/深度学习 算法 程序员
读《趣学算法》:重开算法之门,时间复杂度与空间复杂度
本文是作者阅读《趣学算法》后的笔记,介绍了算法复杂度的基本概念,包括时间复杂度和空间复杂度的不同阶表示,并通过具体例子展示了如何计算和理解算法的效率。
68 2
读《趣学算法》:重开算法之门,时间复杂度与空间复杂度
|
5月前
|
机器学习/深度学习 存储 算法
颠覆认知!Python算法设计中的时间复杂度与空间复杂度,你真的理解对了吗?
【7月更文挑战第22天】在Python算法设计中,时间与空间复杂度是评估算法效能的核心。时间复杂度不仅限于大O表示法,还涵盖平均与最坏情况分析。空间复杂度虽关注额外存储,但也反映内存效率。平衡二者需视场景而定,如利用原地算法减少内存消耗,或牺牲空间加速执行。算法优化技巧,如分治与动态规划,助你在资源与速度间找寻最优解,从而高效应对大数据挑战。
56 3
|
2月前
|
存储 算法
算法的时间复杂度和空间复杂度
本文详细讨论了算法的时间复杂度和空间复杂度,包括它们的概念、计算方法和常见复杂度的对比,并通过多个实例解释了如何计算算法的时间和空间复杂度。
129 0
算法的时间复杂度和空间复杂度
|
2月前
|
机器学习/深度学习 存储 算法
【初阶数据结构】算法效率大揭秘 | 时间与空间复杂度的深度剖析
【初阶数据结构】算法效率大揭秘 | 时间与空间复杂度的深度剖析
|
3月前
|
算法 Python
震惊!Python 算法设计背后,时间复杂度与空间复杂度的惊天秘密大起底!
在 Python 算法设计中,理解并巧妙运用时间复杂度和空间复杂度的知识,是实现高效、优雅代码的必经之路。通过不断地实践和优化,我们能够在这两个因素之间找到最佳的平衡点,创造出性能卓越的程序。
41 4
|
3月前
|
缓存 算法 数据处理
时间&空间复杂度,Python 算法的双重考验!如何优雅地平衡两者,打造极致性能?
在Python算法中,时间与空间复杂度的平衡至关重要。时间复杂度反映算法执行时间随输入规模的变化趋势,空间复杂度则关注额外存储空间的需求。优秀的算法需兼顾两者,如线性搜索时间复杂度为O(n),空间复杂度为O(1);二分查找在时间效率上显著提升至O(log n),空间复杂度保持为O(1);动态规划通过牺牲O(n)空间换取O(n)时间内的高效计算。实际应用中,需根据具体需求权衡,如实时数据处理重视时间效率,而嵌入式系统更关注空间节约。通过不断优化,我们能在Python中找到最佳平衡点,实现高性能程序。
78 3
|
2月前
|
算法 C语言
深入理解算法效率:时间复杂度与空间复杂度
深入理解算法效率:时间复杂度与空间复杂度
|
4月前
|
搜索推荐
九大排序算法时间复杂度、空间复杂度、稳定性
九大排序算法的时间复杂度、空间复杂度和稳定性,提供了对各种排序方法效率和特性的比较分析。
179 1
|
5月前
|
存储 算法 搜索推荐
深度剖析 Python 算法:时间复杂度与空间复杂度的爱恨情仇,你站哪边?
【7月更文挑战第23天】在Python算法设计中,时间复杂度与空间复杂度如影随形,反映算法效率与资源消耗。时间复杂度揭示算法随输入规模增长的计算趋势,空间复杂度关注额外存储需求。找最大值示例中,两种实现均具O(n)时间与O(1)空间复杂度,但在排序等复杂场景下,如冒泡排序与快速排序,或哈希表与二叉树查找,权衡变得关键。实时系统偏好低时间复杂度算法,存储受限环境则需关注空间效率。最佳选择依应用场景而定,掌握二者平衡,方能编写高效代码。
44 10