数据结构之顺序表

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

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

顺序表的结构

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

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

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

顺序表相关函数的实现

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

初始化

判空

销毁

打印

扩容

查找对应数据最小的下标

指定位置插入删除

前插

尾插

取前数据

取后数据

前删

尾删

举例

顺序表的运用

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

顺序表的缺点

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

相关推荐
Hygge-star2 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
加什么瓦3 小时前
Redis——底层数据结构
数据结构
小狗祈祷诗4 小时前
day22-数据结构之 栈&&队列
c语言·数据结构
AI+程序员在路上4 小时前
XML介绍及常用c及c++库
xml·c语言·c++
软行4 小时前
LeetCode 每日一题 3341. 到达最后一个房间的最少时间 I + II
数据结构·c++·算法·leetcode·职场和发展
sz66cm8 小时前
算法基础 -- 小根堆构建的两种方式:上浮法与下沉法
数据结构·算法
顾小玙8 小时前
数据结构进阶:AVL树与红黑树
数据结构
小刘要努力呀!8 小时前
嵌入式开发学习(第二阶段 C语言基础)
c语言·学习·算法
草莓熊Lotso8 小时前
【C语言字符函数和字符串函数(一)】--字符分类函数,字符转换函数,strlen,strcpy,strcat函数的使用和模拟实现
c语言·开发语言·经验分享·笔记·其他
野曙9 小时前
快速选择算法:优化大数据中的 Top-K 问题
大数据·数据结构·c++·算法·第k小·第k大