C++空间复杂度计算方法
2017-09-07 18:52
155 查看
空间复杂度定义
空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度。一个算法在计算机存储器上所占用的存储空间,包括程序代码所占用的空间,输入数据所占用的空间和辅助变量所占用的空间这三个方面。
空间复杂度计算
[b]算法的输入输出数据所占用的存储空间是由要解决的问题决定的,是通过参数表由调用函数传递而来的,它不随本算法的不同而改变。[/b][b]存储算法本身所占用的存储空间与算法书写的长短成正比,要压缩这方面的存储空间,就必须编写出较短的算法。[/b]
[b]算法在运行过程中临时占用的存储空间随算法的不同而异,有的算法只需要占用少量的临时工作单元,而且不随问题规模的大小而改变,我们称这种算法是“就地”进行的,是节省存储的算法;有的算法需要占用的临时工作单元数与解决问题的规模n有关,它随着n的增大而增大,当n较大时,将占用较多的存储单元,例如快速排序和归并排序算法就属于这种情况。[/b]
分析一个算法所占用的存储空间要从各方面综合考虑。如对于递归算法来说,一般都比较简短,算法本身所占用的存储空间较少,但运行时需要一个附加堆栈,从而占用较多的临时工作单元;若写成非递归算法,一般可能比较长,算法本身占用的存储空间较多,但运行时将可能需要较少的存储单元。
一个算法的空间复杂度[b]只考虑在运行过程中为局部变量分配的存储空间的大小,它包括为参数表中形参变量分配的存储空间和为在函数体中定义的局部变量分配的存储空间两个部分。[/b]
若一个算法为递归算法,其空间复杂度为递归所使用的堆栈空间的大小,它等于一次调用所分配的临时存储空间的大小乘以被调用的次数(即为递归调用的次数加1,这个1表不开始进行的一次非递归调用)。
算法的空间复杂度一般也以数量级的形式给出。如当一个算法的空间复杂度为一个常量,即不随被处理数据量n的大小而改变时,可表示为O(1);当一个算法的空间复杂度与以2为底的n的对数成正比时,可表示为0(log2n);当一个算法的空I司复杂度与n成线性比例关系时,可表示为0(n).若形参为数组,则只需要为它分配一个存储由实参传送来的一个地址指针的空间,即一个机器字长空间;若形参为引用方式,则也只需要为其分配存储一个地址的空间,用它来存储对应实参变量的地址,以便由系统自动引用实参变量。
相关文章推荐
- C# 中使用 MD5 算法计算 hash (哈希)值的四种方法
- 计算程序运行时间的方法
- 图像相似度计算之直方图方法OpenCV实现
- 使用matlab版本计算HOG 最为简单的计算方法 使用 vlfeat
- 利用Excel中VBA的Evaluate方法对字符串进行解析计算
- js计算触摸距离方法
- 计算程序或方法的运行时间
- 批处理计算时间差的方法总结
- 【算法学习笔记】52.一道题的三种方法..二分答案、动态规划、计算几何 SJTU OJ 1250 BestSubsequence
- 带宽单位计算方法与关系
- Python 26进制计算实现方法
- Matlab 实现 数值计算方法 二分法
- 基于距离的数学计算方法
- 6_资金收支计算的方法
- js计算德州扑克牌面值的方法
- 计算代码执行时间的方法
- 等效于35mm相机焦距的计算方法
- 数值计算方法程序库
- MDX常见计算方法(百分比/分配/平均值/基于时间的计算)
- php计算整个目录大小的方法