新闻资讯
看你所看,想你所想

空间複杂度

空间複杂度

空间複杂度

空间複杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度,记做S(n)=O(f(n))。比如直接插入排序的时间複杂度是O(n^2),空间複杂度是O(1) 。而一般的递归算法就要有O(n)的空间複杂度了,因为每次递归都要存储返回信息。一个算法的优劣主要从算法的执行时间和所需要占用的存储空间两个方面衡量。

基本介绍

  • 中文名:空间複杂度
  • 外文名:space complexity
  • 记做:S(n)=O(f(n))。
  • 衡量:执行时间和所需要占用的存储空间

量度简介

类似于时间複杂度的讨论,一个算法的空间複杂度S(n)定义为该算法所耗费的存储空间,它也是问题规模n的函式。渐近空间複杂度也常常简称为空间複杂度。空间複杂度(SpaceComplexity)是对一个算法在运行过程中临时占用存储空间大小的量度。一个算法在计算机存储器上所占用的存储空间,包括存储算法本身所占用的存储空间,算法的输入输出数据所占用的存储空间和算法在运行过程中临时占用的存储空间这三个方面。算法的输入输出数据所占用的存储空间是由要解决的问题决定的,是通过参数表由调用函式传递而来的,它不随本算法的不同而改变。存储算法本身所占用的存储空间与算法书写的长短成正比,要压缩这方面的存储空间,就必须编写出较短的算法。算法在运行过程中临时占用的存储空间随算法的不同而异,有的算法只需要占用少量的临时工作单元,而且不随问题规模的大小而改变,我们称这种算法是“就地\"进行的,是节省存储的算法,有的算法需要占用的临时工作单元数与解决问题的规模n有关,它随着n的增大而增大,当n较大时,将占用较多的存储单元,例如快速排序和归併排序算法就属于这种情况。

分析

分析一个算法所占用的存储空间要从各方面综合考虑。如对于递归算法来说,一般都比较简短,算法本身所占用的存储空间较少,但运行时需要一个附加堆叠,从而占用较多的临时工作单元;若写成非递归算法,一般可能比较长,算法本身占用的存储空间较多,但运行时将可能需要较少的存储单元。
一个算法的空间複杂度只考虑在运行过程中为局部变数分配的存储空间的大小,它包括为参数表中形参变数分配的存储空间和为在函式体中定义的局部变数分配的存储空间两个部分。若一个算法为递归算法,其空间複杂度为递归所使用的堆叠空间的大小,它等于一次调用所分配的临时存储空间的大小乘以被调用的次数(即为递归调用的次数加1,这个1表示开始进行的一次非递归调用)。算法的空间複杂度一般也以数量级的形式给出。如当一个算法的空间複杂度为一个常量,即不随被处理数据量n的大小而改变时,可表示为O(1);当一个算法的空间複杂度与以2为底的n的对数成正比时,可表示为O(log2n);当一个算法的空间複杂度与n成线性比例关係时,可表示为O(n).若形参为数组,则只需要为它分配一个存储由实参传送来的一个地址指针的空间,即一个机器字长空间;若形参为引用方式,则也只需要为其分配存储一个地址的空间,用它来存储对应实参变数的地址,以便由系统自动引用实参变数。

时间空间複杂度

对于一个算法,其时间複杂度和空间複杂度往往是相互影响的。当追求一个较好的时间複杂度时,可能会使空间複杂度的性能变差,即可能导致占用较多的存储空间;反之,当追求一个较好的空间複杂度时,可能会使时间複杂度的性能变差,即可能导致占用较长的运行时间。另外,算法的所有性能之间都存在着或多或少的相互影响。因此,当设计一个算法(特别是大型算法)时,要综合考虑算法的各项性能,算法的使用频率,算法处理的数据量的大小,算法描述语言的特性,算法运行的机器系统环境等各方面因素,才能够设计出比较好的算法。算法的时间複杂度和空间複杂度合称为算法的複杂度。

转载请注明出处海之美文 » 空间複杂度

相关推荐

    声明:此文信息来源于网络,登载此文只为提供信息参考,并不用于任何商业目的。如有侵权,请及时联系我们:ailianmeng11@163.com