目录
1. 空间复杂度的概念
空间复杂度也是一个数学表达式,是对一个算法在运行过程中临时占用存储空间大小的量度。
空间复杂度不是程序占用了多少bytes空间,空间复杂度算的是变量的个数。
空间复杂度计算规则基本和世纪那复杂度类似,也用到 大O渐近表示法。
注意:函数运行时所需要的栈空间(存储参数、局部变量,一些寄存器信息等等)再编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显示申请的二外空间来确定。
空间复杂度在日常中没那么重要,如今手机、电脑的存储空间越来越大,算法更关注时间。
有时甚至可以牺牲一些空间复杂度来换取时间复杂度。
空间是可以重复使用的,时间一去不返所以是累加。
常见的空间复杂度有:、
、
、
、
、
、
2. 例题
2.1 计算BubbleSort的空间复杂度
void BubbleSort(int a, int n)
{
assert(a);
for (size_t end = n; end > 0; --end)
{
int exchange = 0;
for (size_t i = 1; i < end; ++i)
{
if (a[i - 1] > a[i])
{
Swap(&a[i - 1], &a[i]);
exchange = 1;
}
}
if (exchange == 0)
break;
}
}
BubbleSort使用了常数个额外的空间,所以它的空间复杂度是
2.2 计算Fibonacci的空间复杂度
long long* Fibonacci(size_t n) {
if (n == 0)
return NULL;
long long* fibArray = (long long*)malloc((n + 1) * sizeof(long long));
fibArray[0] = 0;
fibArray[1] = 1;
for (int i = 2; i < n; ++i)
{
fibArray[i] = fibArray[i - 1] + fibArray[i - 2];
}
return fibArray;
}
很明显,Fibonacci动态开辟了N个空间,所以它的空间复杂度是
2.3 计算阶乘递归Fac的空间复杂度
long long Fac(size_t N) {
if (0 == N)
return 1;
return Fac(N - 1) * N;
}
Fac递归调用了N次,开辟了N个栈帧,每个栈帧使用了常数个空间,所以它的时间复杂度是