算法的空间复杂度

空间复杂度

空间复杂度 主要是衡量一个算法运行所需要的额外空间 ,在计算机发展早期 ,计算机的储存容量很小 ,所以空间复杂度是很重要的。但是经过计算机行业的迅速发展 ,计算机的容量已经不再是问题了,所以如今已经不再需要特别关注一个算法的空间复杂度。

空间复杂度也是一个数学表达式,是对一个算法的运行过程中临时占用储存空间大小的量度。

空间复杂度不是程序占用了多少bytes的空间,而是变量个数。空间复杂度计算也是使用大O渐进表示法。

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

例1:

cpp 复制代码
void Bubblesort(int* a, int sz)
{
    for(int i = 0; i < sz-1; i++)
    {
        int exchange = 0;
        for(int j = 0; j < sz-1-i; j++)
        {
            if(a[j] > a[j+1])
            {
                int tmp = a[j];
                a[j] = a[j+1];
                a[j+1] = tmp;
                exchange = 1;
            }
        }
        if(exchange == 0)
            break;
    }
}

冒泡排序,只使用了常数个空间,所以空间复杂度为 O(1);

例2:

cpp 复制代码
int* Fib(int n)
{
    if(n == 0)
        return NULL;
    int* fibarr = (int*)malloc(sizeof(int)*(n+1));
    fibarr[0] = 0;
    fibarr[1] = 1;
    for(int i = 2; i <= n; i++)
    {
        fibarr[i] = fibarr[i-1] + fibarr[i-2];
    }
    return fibarr;
}

fibarr开辟了N个int类型的空间,所以空间复杂度为O(N)

例3:

cpp 复制代码
int fac(int n)
{
    if(n == 0)
        return 1;
    
    return fac(n-1)*n;
}

再fac函数中调用了N次fac函数,递归了N次,开辟了N个栈帧,每个栈使用了常数个空间,所以空间复杂度O(N)

例4:

请回答fib函数的空间复杂度是多少?

cpp 复制代码
int fib(int n)
{
    if(n < 3)
        return 1;

    return fib(n-1) + fib(n-2);
}

A. O(1) B.O(N) C.O(N^2) D.O(2^N)

.

.

.

.

.

.

.

.

.

.

.

.

.

.

答案:O(N)

对于 fib(n),递归调用的最大深度取决于 n,因为每次递归都会对 n−1或 n−2进行调用。

尽管函数中有很多重复计算(导致时间复杂度是指数级的),但调用栈的最大深度只与输入 n 的大小成线性关系。

比如调用 fib(n),最深的递归路径是 fib(n) → fib(n-1) → fib(n-2) → ... → fib(1)

每次递归调用都需要在栈上分配空间。最大栈深度是递归树的高度。在这种实现方式下,递归树的高度为 O(n)。

相关推荐
鱼跃鹰飞6 小时前
Leetcode347:前K个高频元素
数据结构·算法·leetcode·面试
好评1246 小时前
【C++】二叉搜索树(BST):从原理到实现
数据结构·c++·二叉树·二叉搜索树
程序猿炎义7 小时前
【Easy-VectorDB】Faiss数据结构与索引类型
数据结构·算法·faiss
jiaguangqingpanda9 小时前
Day24-20260120
java·开发语言·数据结构
ValhallaCoder9 小时前
Day53-图论
数据结构·python·算法·图论
C雨后彩虹9 小时前
羊、狼、农夫过河
java·数据结构·算法·华为·面试
Elastic 中国社区官方博客9 小时前
使用瑞士风格哈希表实现更快的 ES|QL 统计
大数据·数据结构·sql·elasticsearch·搜索引擎·全文检索·散列表
重生之后端学习10 小时前
19. 删除链表的倒数第 N 个结点
java·数据结构·算法·leetcode·职场和发展
aini_lovee10 小时前
严格耦合波(RCWA)方法计算麦克斯韦方程数值解的MATLAB实现
数据结构·算法·matlab
Remember_99310 小时前
【数据结构】深入理解优先级队列与堆:从原理到应用
java·数据结构·算法·spring·leetcode·maven·哈希算法