数据结构之顺序表

顺序表就是一个结构体记录了数组的最大容量和当前容量以及数组指针。通过开辟内存的函数来实现内存的自动扩容。

下面我用c语言来对其进行说明讲解:

顺序表的结构

如下图,基本结构就是一个利用堆区开辟的数组。利用结构体来管理这个结构,相比于传统的数组,这个数据结构更加的灵活,方便。

例如我们在c中,可以用到realloc来实现数组的开辟或者数组的扩容那么我们创建熟悉表只需要库库往里面插入,完全不用考虑会不会越界访问,数组内存不够的问题

通过定义type可以方便的替换我们的数组类型。

顺序表相关函数的实现

我们要对以上这些基础且重要的函数进行实现

初始化

判空

销毁

打印

扩容

查找对应数据最小的下标

指定位置插入删除

前插

尾插

取前数据

取后数据

前删

尾删

举例

顺序表的运用

顺序表的运用很多,例如栈就可以用顺序表实现。在cpp里面的向量就是顺序表。因为自动扩容的特定让我们存取数据相对的方便。

顺序表的缺点

顺序表出了尾插,和尾删,其他地方删除都是比较费时间的一件事。当数据足够大的时候,我们的顺序表中的增删操作就会耗时。时间复杂度是O(N)

相关推荐
Controller-Inversion21 分钟前
23. 合并 K 个升序链表
数据结构·链表
Mr_pyx31 分钟前
面试题记录
jvm·数据结构·算法·spring·mybatis
努力努力再努力wz40 分钟前
【C++高阶数据结构系列】:时间轮定时器详解:原理分析与代码实现,带你从零手撕时间轮!(附时间轮的实现源码)
c语言·开发语言·数据结构·c++·qt·算法·ui
水饺编程1 小时前
编程基础:令牌粘贴指令,【##】
c语言·c++·windows·visual studio
Chen_harmony1 小时前
十九、数据在内存中的存储
c语言·开发语言
basketball6161 小时前
C 的 malloc/free 与 C++ 的 new/delete 一些区别
c语言·开发语言·c++
iiiiyu1 小时前
⾯向对象和集合编程题
java·大数据·开发语言·数据结构·编程语言
YuanDaima20481 小时前
贪心算法基础原理与题目说明
数据结构·人工智能·python·算法·贪心算法·手撕代码
爱编码的小八嘎1 小时前
MFC深入-消息映射的实现
c语言
人道领域1 小时前
【LeetCode刷题日记】513.二叉树左下角值的三种解法:从常规BFS到DFS的优雅之旅
数据结构·算法·leetcode·深度优先·广度优先