空间复杂度(数据结构)

概念:

  空间复杂度也是一个数学表达式,是对一个算法在运行过程中临时占用存储空间大小的量度 。
空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。空间复杂度计算规则基本跟实践复杂度类似,也使用大O渐进表示法。


  注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显式申请的额外空间来确定。

实例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;
 }
}

实例2:

// 计算Fibonacci的空间复杂度?
// 返回斐波那契数列的前n项
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;
}

实例3:

// 计算阶乘递归Fac的空间复杂度?
long long Fac(size_t N)
{
 if(N == 0)
 return 1;
 
 return Fac(N-1)*N;
}

实例答案及分析:

1. 实例1使用了常数个额外空间,所以空间复杂度为 O(1)
2. 实例2动态开辟了N个空间,空间复杂度为 O(N)
3. 实例3递归调用了N次,开辟了N个栈帧,每个栈帧使用了常数个空间。空间复杂度为O(N)

这个博客如果对你有帮助,给博主一个免费的点赞就是最大的帮助

欢迎各位点赞,收藏和关注哦

如果有疑问或有不同见解,欢迎在评论区留言哦

后续我会一直分享双一流211西北大学软件(C,数据结构,C++,Linux,MySQL)的学习干货以及重要代码的分享

相关推荐

  1. 数据结构6:时间复杂空间复杂

    2024-03-10 18:46:02       142 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-10 18:46:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-10 18:46:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-10 18:46:02       82 阅读
  4. Python语言-面向对象

    2024-03-10 18:46:02       91 阅读

热门阅读

  1. Python与FPGA——帧间差算法

    2024-03-10 18:46:02       42 阅读
  2. Ajax与jQuery

    2024-03-10 18:46:02       39 阅读
  3. 轮询--一起学习吧之架构

    2024-03-10 18:46:02       39 阅读
  4. [LeetCode][LCR184]设计自助结算系统——单调队列

    2024-03-10 18:46:02       40 阅读
  5. Hive动态分区静态分区

    2024-03-10 18:46:02       44 阅读
  6. 双非二本实习前的准备day8

    2024-03-10 18:46:02       38 阅读
  7. CentOS上安装与配置Nginx

    2024-03-10 18:46:02       42 阅读
  8. linux tar分卷压缩与windows合并解压

    2024-03-10 18:46:02       40 阅读
  9. 安卓 Kotlin 面试

    2024-03-10 18:46:02       38 阅读
  10. C语言 goto 语句的基本格式是什么?如何使⽤?

    2024-03-10 18:46:02       37 阅读