数据结构之顺序表

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

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

顺序表的结构

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

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

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

顺序表相关函数的实现

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

初始化

判空

销毁

打印

扩容

查找对应数据最小的下标

指定位置插入删除

前插

尾插

取前数据

取后数据

前删

尾删

举例

顺序表的运用

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

顺序表的缺点

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

相关推荐
时间的拾荒人10 小时前
C语言字符函数与字符串函数完全指南
c语言·开发语言
持力行10 小时前
C/C++ 中的 char*:它标识数组吗?为什么能用下标访问?
c语言·c++
小陈的代码之路13 小时前
回文链表(LeetCode 234)C语言最佳解题思路
c语言·leetcode·链表
aaaameliaaa14 小时前
计算斐波那契数(递归、迭代)(1,1,2,3,5.....)
c语言·开发语言·笔记·算法·排序算法
金融小师妹14 小时前
人工智能推演框架:非农降温信号如何重构黄金定价模型
数据结构·人工智能·机器学习·transformer
zhangfeng113316 小时前
算子开发 Overwrite 覆盖/替换模式 Accumulate 累加模式,性能对比 memset错误 bat_alloc 错误
c语言·人工智能·gnu·算子开发
SuperByteMaster17 小时前
JLinkDevices.xml FLM文件路径不对
c语言
ysa05103017 小时前
【并查集】判环,深搜
数据结构·c++·算法·深度优先
LDR00617 小时前
LDR6500赋能POS机底座:单口Type-C供电、维护与产测一体化解决方案
大数据·c语言·人工智能
鱼很腾apoc18 小时前
【Linux】第7期 进程间通信 (IPC) 详解:管道 (匿名 / 命名) + System V
linux·服务器·c语言·学习·进程间通信·ipc