空间复杂度

基本概念

空间复杂度是对一个算法在运行过程当中临时占用存储空间大小的一个量度,咱们用 S(n) 来定义。web

计算方法

1. 空间复杂度 O(1)
若是算法执行所须要的临时空间不随着某个变量n的大小而变化,即此算法空间复杂度为一个常量,可表示为 O(1)算法

int i = 1;
int j = 2;
++i;
j++;
int m = i + j;

变量 i、j、m 所分配的空间都不随着处理数据量变化,所以它的空间复杂度 S(n) = O(1)数组

2. 空间复杂度 O(n)svg

int[] m = new int[n]
for(i=1; i<=n; ++i)
{
   j = i;
   j++;
}

这段代码中,第一行new了一个数组出来,这个数据占用的大小为n,这段代码的2-6行,虽然有循环,但没有再分配新的空间,所以,这段代码的空间复杂度主要看第一行便可,即 S(n) = O(n)code

转自:https://zhuanlan.zhihu.com/p/50479555xml