【数据结构与算法】顺序表

顺序表

一.顺序表的原理

1.是什么

顺序表 是一种线性的结构,类似于数组,但是中间不能有空值.

元素顺序地存储在一段连续的内存空间中.

顺序表中的元素类型是相同的.

顺序表的大小是固定的.

查找的速度很快,但是插入和删除需要移动大量的元素.

适用于元素访问频繁,但插入和删除操作较少的场景。

2.数据结构

包含一个基地址指针,一个记录当前个数的长度,和一个初始化顺序表的大小的结构体.

顺序表里面什么类型的都可以,我这里是自定义的人类结构体.

二.顺序表的初始化

初始化我们就需要对结构体的3个值进行赋值.

基地址,我们new 手动开辟堆区内存

当前长度初始化为0

内存大小自己设定

当然这里做了一下防御性编程,如果堆区内存没有开辟成功就直接返回.

随便定义的一个宏.

三.顺序表增加元素

因为我们手动开辟的空间是一个数组,所以我们可以通过下标来进行添加数据.

因为我们添加数据是一个一个进行添加,相当于尾插法,而且数组的下标是从0开始.

所以我们可以直接通过,当前长度为下标进行添加,然后对当前长度加1.

当然如果内存满了就添加不了了,直接退出.

四.顺序表插入元素

插入元素就很好玩了,需要进行乾坤大罗伊,容我画个图,带你理解.

所以当我们要在数组某个位置插入一个图的时候,我们也需要进行移动.

那么如何能达到这种移动的效果呢,其实就是相当于覆盖,将前一个的值赋值到后面一个值.

为了保证值不受影响,我们从后往前进行赋值.

参数i是插入的位置,people是插入的元素.

我们需要做防御性编程,插入的位置不能离谱,还有满了就不能插了

从当前有的最后一个值的后一个开始,依次将前面的值赋值到后面.

在要插入的位置就设置当前要插入的值.

五.顺序表删除元素

原理跟插入是差不多的,也需要大量的移动.

只不过这次是将后面的值赋值到前面.

相当于是将要删除的值进行了覆盖,从而达到元素删除的效果.

当然,这里有一个要删除的特殊位置,那就是当删除的是顺序表的尾巴的时候,我们可以直接对当前值减一即可,访问不到.相当于就是删除.

六.顺序表的销毁

这个就很简单了,newdelete 来进行销毁.

如果基地址不为空,就进行销毁,同时将长度和大小都设置为0.

七.总结

总的来说,顺序表的应用十分广泛,它在许多领域中都发挥着重要的作用,特别是当需要快速随机访问数据时。

相当于是数组的升级版可以进行插入和删除数据,使其更加的灵活.

相关推荐
Json____8 分钟前
Java练习题集-温度转换、成绩等级、九九乘法表等实战小项目15个
java·学习·编程学习·java学习·练习题集
一只数据集10 分钟前
Unitree G1苹果拾取放置深度数据集:963条高质量RGB-D操作轨迹助力3D感知与机器人学习
人工智能·学习·3d·机器人·制造
Black蜡笔小新12 分钟前
自动化AI算法训练服务器/企业AI算力工作站DLTM重塑企业AI开发模式赋能企业智能转型
人工智能·算法·自动化
科研小白_15 分钟前
【第一期:MATLAB点云处理基础】LAS点云数据导入与可视化
算法
2zcode15 分钟前
基于Matlab不规则颗粒粒径周长面积测量及计数系统
开发语言·算法·matlab
renhongxia118 分钟前
开源大模型VS闭源大模型:2026年格局再梳理
深度学习·算法·语言模型·分类·开源
笨笨饿19 分钟前
#85_库函数开发
linux·c语言·网络·stm32·单片机·算法·个人开发
远离UE420 分钟前
Forward+ & Deferred+学习笔记
笔记·数码相机·学习
lightqjx23 分钟前
【数据结构】图论基础_基本概念_存储_遍历
数据结构·图论·图的遍历·图的存储