【数据结构】顺序表

线性表(/inear list)是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使 用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串.

线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。

1.概念和结构

概念

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。

结构

顺序表的底层结构是数组,顺序表是用数组来实现的

(顺序表 = 数组+增添数据+删除数据+修改数据+查询数据......)

分类:

静态顺序表和动态顺序表

静态顺序表

使用定长数组存储元素

缺点:空间给少了不够用,给多了造成空间浪费。

动态顺序表

底层数组的空间大小在不断变化

定义
初始化

注意:要使用传址调用

尾插法

在插入新元素时要考虑原数组的空间大小,注意不要跃界。

当空间不足时,就需要增加原数组的空间,此时就需要realloc函数帮助。

那么一次性加多少空间呢?

如果一次性加的过少,那么效率就会下降,加的过多就很容易造成浪费。所以,每次扩容时,使原空间加倍最好(我也不知道为啥,大佬研究的,跟概率学相关)

注意:扩容时最好新建tmp数组,如果直接在原数组扩容容易造成数据丢失。

时间复杂度:O(1);

头插法:

与尾插相似,注意判断空指针,以及检查空间是否不足。不一样的是,需要把每个数据后移一位。

时间复杂度:O(n);

尾删

时间复杂度:O(1);

头删

时间复杂度:O(n);

之间插入

注意判断空指针以及越界问题即可

时间复杂度:O(n);

之间位置删除:

注意判断空指针以及越界问题即可

时间复杂度:O(n);

查找:
销毁:

注意free后要初始化。

相关推荐
希赛网1 分钟前
软考软件设计师常考知识点:(三)数据结构
数据结构·二叉树·字符串·软考·软件设计师·线性表
雨夜的星光3 分钟前
Python JSON处理:load/loads/dump/dumps全解析
开发语言·python·json
迎風吹頭髮26 分钟前
UNIX下C语言编程与实践62-UNIX UDP 编程:socket、bind、sendto、recvfrom 函数的使用
c语言·单片机·unix
fen_fen1 小时前
Java打包时,不将本地Jar打包到项目的最终 JAR 中
开发语言·python·pycharm
繁花与尘埃3 小时前
HTML5简介与基本骨架(本文为个人学习笔记,内容整理自哔哩哔哩UP主【非学者勿扰】的公开课程。 > 所有知识点归属原作者,仅作非商业用途分享)
笔记·学习·html5
wjs20243 小时前
SQL AND & OR 操作符详解
开发语言
~光~~3 小时前
【环境配置 】WSL2 +ubuntu20.04 +Qt配置+Kits配置
开发语言·qt·ubuntu
·心猿意码·4 小时前
C++右值语义解析
开发语言·c++
小龙报4 小时前
《彻底理解C语言指针全攻略(2)》
c语言·开发语言·c++·visualstudio·github·学习方法
Rock_yzh4 小时前
AI学习日记——卷积神经网络(CNN):完整实现与可视化分析
人工智能·python·深度学习·神经网络·学习·cnn