数据结构之【顺序表简介】

1.顺序表的概念

顺序表 是 用一段物理地址连续的存储单元 依次 存储数据元素的线性结构

一般情况下采用数组存储

2.顺序表的结构

既然顺序表 可以用来存储数据元素

那就少不了 增删查改 的操作

此时,单一地只创建数组满足不了上述操作

创建相应的结构体变量可以很好地解决这个问题

2.1重命名数据类型名称

复制代码
typedef int SLDataType;

重命名一下数据类型的名称

这样

之后改变数据类型的时候只需要修改一处
SL是Seqlist,即顺序表的英文缩写

DataType 是数据类型的英文缩写

2.2静态顺序表

所谓静态:使用定长数组存储数据

复制代码
#define N 5

typedef struct SeqList
{
	SLDataType arr[N];  //定长数组
	int size;   //有效数据个数
}SL;

如上图:

定义的结构体包含

一个定长数组和一个变量

数组用来存储数据,

变量用来存储有效数据的个数
很显然,

静态顺序表存在很大的缺陷,

因为

不能根据需要合理定义数组的大小

开100个单元存不下101个数据

开1万个单元存不下1万零1个数据

开10万个单元如果只存10个数据,又会浪费空间
所以我们更多的选择使用动态顺序表

按需申请空间

2.3动态顺序表

复制代码
typedef struct SeqList
{
	//该指针指向所申请的空间首地址
	SLDataType* arr; 
	int size;       //有效数据个数
	int capacity;   //空间容量
}SL;

如上图:

定义的结构体中,

arr 指向动态开辟的内存空间

size 存储有效数据个数

capacity表示空间容量,空间不够就扩容

相关推荐
水蓝烟雨1 小时前
0430. 扁平化多级双向链表
数据结构·链表
阿巴~阿巴~2 小时前
Linux线程与进程的栈管理、页表机制及线程封装
数据结构·线程·进程·线程封装·页表机制·栈管理
立志成为大牛的小牛2 小时前
数据结构——三十一、最小生成树(王道408)
数据结构·学习·程序人生·考研·算法
JMzz2 小时前
Rust 中的数据结构选择与性能影响:从算法复杂度到硬件特性 [特殊字符]
开发语言·数据结构·后端·算法·性能优化·rust
星空露珠4 小时前
数独生成题目lua脚本
数据结构·数据库·算法·游戏·lua
给大佬递杯卡布奇诺5 小时前
FFmpeg 基本数据结构 URLContext分析
数据结构·c++·ffmpeg·音视频
极客智造14 小时前
线性数据结构深度解析:数组、链表、栈与队列的实现与应用
数据结构·链表
Zhu_S W15 小时前
Redis跳表:高效有序数据结构的深度剖析
数据结构·数据库·redis
是那盏灯塔15 小时前
【算法】——动态规划之01背包问题
数据结构·c++·算法·动态规划
jinmo_C++16 小时前
数据结构_深入理解堆(大根堆 小根堆)与优先队列:从理论到手撕实现
java·数据结构·算法