空间复杂度与顺序表的具体实现操作(1)
创始人
2024-05-29 12:47:03
0

最近更新的少,主要是因为参加了ACM竞赛

空间复杂度

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

  1. 空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。

  1. 空间复杂度计算规则基本跟实践复杂度类似,也使用大O渐进表示法。

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

  1. 时间一去不复返,也就是说不能够重复利用;但是空间用了之后就能够归还,因此空间可以重复利用,比如下面这个例子:

上面这个的空间复杂度就是O(N),因为我要运行这个算法在这个过程当中,我需要去额外开辟空间,这是跟我的数据源无关的,我额外开辟的空间。

当前函数在调用的时候,为开辟对应的函数栈帧,如果函数里面又会调用函数,那么当前函数的函数栈帧并不会被销毁,上面这个的空间复杂度也是O(N)

那么重头戏来了,这个的空间复杂度是多少?首先的话必须要了解到底函数的调用顺序是怎么样的?就看我的这张图:

这种函数执行的顺序有点类似于深度优先搜索,到底了之后那个函数执行结束之后就会销毁函数栈帧,接下来再去调用函数,对于总的空间来说已经不会再增加,因此空间复杂度就是O(N)。

  1. 虽然说空间复杂度统计的是变量的个数,如果说函数里面并没有创建变量,那么我们认为在这个函数栈帧里面的空间大小为一个常数,也就是O(1)。

  1. 对于数组而言,有几个元素就表示所谓的变量个数。

线性表

  1. 数据结构的作用:在内存当中存储与管理数据。

  1. 线性表是n个具有相同特性的数据元素的有限序列,线性表是一种常用的数据结构。比较常见的线性表有:顺序表,链表,栈,队列,字符串.......。我们说线性表在逻辑上是线性结构,也就是说好比一条连续的直线。但是在物理结构上并不一定是连续的。在物理上存储时,通常以数组和链式结构的形式存储

顺序表(SeqList)

  1. 顺序表就是写一个结构体,然后通过这个结构对数组进行管理,存储数据就是用数组存储

1.创建一个顺序表

//创建一个结构体
typedef int SLDataType;
typedef struct SeqList
{SLDataType* p;size_t size;size_t capacity;
}SeqList;

2.顺序表的初始化

#define INIT_CAPACITY 5
void SeqListInit(SeqList* ps)
{ps->p = (SeqList*)malloc(sizeof(SLDataType) * INIT_CAPACITY);if (ps->p = NULL){perror("SeqListInit::Malloc:");return;}ps->size = 0;ps->capacity = INIT_CAPACITY;
}

3.顺序表使用结束后的销毁

void SeqListDestroy(SeqList* ps)
{free(ps->p);ps->p = NULL;ps->capacity = 0;ps->size = 0;
}

4.打印顺序表

void SeqlistPrint(SeqList* ps)
{for (int i = 0; i < ps->size; i++){printf("%d ", *(ps->p + i));}printf("\n");
}

5.顺序表的尾插

void SeqListPushBack(SeqList* ps, SLDataType x)
{if (ps->size == ps->capacity){SLDataType* pp = (SLDataType*)realloc(ps->p, sizeof(SLDataType) * ps->capacity * 2);if (pp == NULL){perror("SeqListPushBack::Realloc");return;}ps->p = pp;}*(ps->p + ps->size) = x;ps->capacity *= 2;ps->size++;
}

6.顺序表的尾删

void SeqListPopBack(SeqList* ps)
{assert(ps->size > 0);ps->size--;
}

未完,待续........

相关内容

热门资讯

安卓12系统侧边小图标 你有没有发现,最近你的安卓手机是不是悄悄地变了个样?没错,就是那个一直默默无闻的侧边小图标,它现在可...
词典笔安卓系统如何升级,词典笔... 你有没有发现,你的词典笔安卓系统突然有点卡卡的呢?别急,别急,今天就来教你怎么给它来个焕然一新的升级...
手机系统安卓10彩蛋,体验科技... 你知道吗?在手机世界里,安卓10系统可是隐藏着不少小秘密哦!今天,就让我带你一起探索安卓10系统中的...
鸿蒙系统也兼容安卓软件,开启跨... 你知道吗?最近科技圈可是炸开了锅,因为华为的鸿蒙系统竟然宣布了一个让人眼前一亮的消息——它要兼容安卓...
澎湃安卓系统怎么样 澎湃安卓系统怎么样?亲爱的读者们,你是否在寻找一款与众不同的安卓系统?如果你对现有的安卓系统有些许厌...
华为安卓套壳系统 你知道吗?最近科技圈里有个大新闻,那就是华为安卓套壳系统的诞生。这可是个让人眼前一亮的技术突破,咱们...
自动接听电话安卓系统,安卓系统... 你有没有想过,当你的手机突然响起,而你正忙得不可开交的时候,如果能有个小助手自动接听电话,那该有多方...
如何制作安卓系统程序 想要自己动手制作一款安卓系统程序吗?别急,让我带你一步步走进这个充满创造力的世界。在这个数字化时代,...
中控不是安卓系统,非安卓系统下... 亲爱的读者,你是否曾好奇过,为什么有些智能设备的中控系统不是安卓系统呢?今天,就让我带你一探究竟,揭...
深度系统deepin支持安卓,... 你知道吗?最近在科技圈里,有个大新闻可是引起了不小的轰动呢!那就是深度系统(Deepin)宣布支持安...
安卓系统怎么解除应用锁,恢复自... 手机里的应用锁是不是让你头疼不已?有时候,我们可能不小心设置了应用锁,或者忘记了密码,这时候就需要解...
安卓系统是否可以看代码,从代码... 你有没有想过,安卓系统那神秘的代码背后藏着怎样的秘密呢?是不是好奇过,自己能不能一窥究竟?今天,就让...
apk怎么连接安卓子系统,安卓... 你有没有想过,你的安卓手机里竟然还隐藏着一个神秘的子系统?没错,就是那个apk怎么连接安卓子系统的问...
安卓系统设置触屏开机,便捷操作... 手机屏幕突然黑屏了,是不是触屏设置出了问题?别急,今天就来手把手教你如何调整安卓系统的触屏开机设置,...
安卓系统访问本地连接,Andr... 你有没有想过,你的安卓手机里那些隐藏的小秘密?比如,如何轻松访问本地连接,让你的手机瞬间变身网络小达...
安卓系统qq坦白说,隐私互动新... 你有没有发现,手机里那个陪伴我们多年的QQ,最近在安卓系统上又有了新变化?没错,就是那个我们每天都要...
制作安卓系统iso镜像,ISO... 亲爱的读者们,你是否曾梦想过亲手打造一个属于你自己的安卓系统?想象那是一个完全按照你的喜好定制的系统...
智慧餐厅系统和安卓区别,技术融... 你有没有想过,未来的餐厅会是什么样子呢?想象你走进一家餐厅,不用排队点餐,不用等待服务员,甚至不用掏...
安卓os手表系统问题,安卓OS... 你有没有发现,最近你的安卓OS手表总是有点儿“闹脾气”?时不时地卡顿有时候还突然关机,真是让人头疼。...
安卓系统版本低光遇,揭秘安卓系... 你有没有发现,最近玩《光遇》的小伙伴们都在抱怨一个问题:安卓系统版本太低,游戏体验大打折扣!这不,今...