数据结构——线性表①(顺序表)
一、线性表定义
线性表是一种数据结构,它是由n个具有相同数据类型
的数据元素a1,a2,…,an组成的有限序列
。
其中,除第一个元素a1外,每一个元素有且只有一个直接前驱元素,除了最后一个元素an外,每一个元素有且只有一个直接后继元素。
线性表可以用顺序存储结构或链式存储结构来实现。
- 顺序表是一种用一段地址连续的存储单元依次存储线性表中的数据元素的存储结构;
- 链表则是一种用一组任意的存储单元存储线性表中的数据元素的存储结构。
【线性表内容框架】
二、线性表特点
- 表中数据元素的个数有限
- 表中元素具有逻辑上的顺序性,表中元素有其先后次序
- 表中元素都是数据元素,每个元素都是单个元素
- 表中的元素数据类型都相同,即每个元素都占有相同大小的存储空间
- 表中元素具有抽象性,即仅讨论元素之间的逻辑关系,而不考虑元素究竟表示什么内容
三、线性表的基本操作
InitList(&L)
:初始化表。构造一个空的线性表L,分配内存空间。DestroyList(&L)
:销毁操作。销毁线性表,并释放线性表L所占用的内存空间。ListInsert(&L,i,e)
:插入操作。在表L中的第i个位置上插入指定元素e。ListDelete(&L,i,&e)
:删除操作。删除表L中第i个位置的元素,并用e返回删除元素的值。LocateElem(L,e)
:按值查找操作。在表L中查找具有给定关键字值的元素。GetElem(L,i)
:按位查找操作。获取表L中第i个位置的元素的值。
【其他操作】
Length(L)
:求表长。返回线性表L的长度,即L中数据元素的个数PrintList(L)
:输出操作。按前后顺序输出线性表L的所有元素值。Empty(L)
:判空操作。若L为空表,则返回true,否则迟回false 。
注意:
上面写的函数严格来说并不正确,因为没有写返回值类型
其次,函数的参数有带符号“&”
的,这是C++的语法,和C语言中的指针效果一致
比如说初始化表的函数,用C语言的写法,也可以写成InitList(<类型名>* L);
要初始化一个数据元素类型为整型的线性表的话,初始化函数可以写成InitList(int* L);
四、线性表的分类
(1)顺序表
1.1 顺序表的定义
线性表的顺序存储叫做顺序表。(用顺序存储的方式实现线性表)
顺序存储——把逻辑上相邻的元素存储在物理位置上也相邻的存储单元中,元素之间的关系由存储单元的邻接关系来体现。需要开辟一段了连续的空间用来存储数据。
1.2 顺序表的创建和初始化及相关操作
这里插一句,顺序表有两种,一种是
动态顺序表
,一种是静态顺序表
。
·静态顺序表使用定长数组存储元素
·而动态顺序表可以动态开辟内存,可以动态改变数组长度
静态顺序表的创建和初始化比较简单,
静态顺序表的创建就是直接在main函数中创建一个SqList 类型的结构体变量
静态顺序表的初始化就是把 链表结构体中的 length 的值设置为0
静态顺序表的基本操作:添加元素(插入元素)、删除元素、修改元素、查找元素
代码如下:
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>#define MaxSize 10 //这里宏定义了静态顺序表最多能存储10个数据struct SqList
{int data[MaxSize];int length;
};
typedef struct SqList SqList;void InitList(SqList* list)//初始化静态顺序表
{list->length = 0;
}int ListInsert(SqList* L, int i, int e)//在表中位置i处,插入数据e
{if (i < 1 || i > L->length + 1 || L->length >= MaxSize) {return 0;}for (int j = L->length; j >= i; j--) {L->data[j] = L->data[j - 1];}L->data[i - 1] = e;L->length++;return 1;
}int ListDelete(SqList* L, int i) //删除表中位序为i的数据元素
{if (i < 1 || i > L->length){return 0;}for (int j = i; j < L->length; j++){L->data[j - 1] = L->data[j];}L->length--;return 1;
}void PrintList(SqList list)//打印顺序表中所有元素
{for (int i = 0; i < list.length; i++){printf("%d ", list.data[i]);}
}int Find(SqList list,int e)//查找顺序表中值为e 的元素,返回其位序,如果没找到,返回0
{if (list.length == 0){return 0;}for (int i = 0; i < list.length; i++){if (list.data[i] == e){return i + 1;}}return 0;
}int Change(SqList* list,int i,int e)//修改位序为i处的数据,把数据改成e
{if (i < 1 || i > list->length + 1 || list->length >= MaxSize) {return 0;}list->data[i-1] = e;return 1;
}
#include"SqList.h"int main()
{SqList L;InitList(&L);ListInsert(&L, 1, 10);//在位序1处插入数字10ListInsert(&L, 2, 20);//在位序2处插入数字20ListInsert(&L, 3, 30);//在位序3处插入数字30PrintList(L);//打印静态顺序表中的所有数据printf("\n");ListDelete(&L, 2);//删除静态顺序表中位序为2的数据(删除20)PrintList(L);printf("\n");int pos1 = Find(L, 20);printf("%d\n", pos1);//0int pos2 = Find(L, 30);printf("%d\n", pos2);//2Change(&L,1,24);PrintList(L);//24 30return 0;
}
动态顺序表的创建和初始化
#define InitSize 10 //顺序表的初始长度
typedef struct
{ElemType *data; //指示动态分配数组的指针int MaxSize; //顺序表的最大容量int length; //顺序表的当前长度
}seqList;
//顺序表的类型定义(动态顺序表)
动态顺序表的好处是可以在容量不够的情况下进行扩容操作
动态顺序表的创建:在main函数中创建一个结构体变量
动态顺序表的初始化:用malloc开辟一段连续空间;初始化最大容量为宏定义的初始化长度;令顺序表的当前长度为0
动态顺序表的增删改查的函数操作实现
代码如下
#define InitSize 10 //顺序表的初始长度
typedef int ElemType;
typedef struct seqList
{ElemType* data; //动态分配数组的指针 int MaxSize; //顺序表的最大容量 int length; //顺序表的当前长度
} seqList;void InitList(seqList* L)//动态顺序表的初始化
{L->data = (int*)malloc(InitSize * sizeof(int));//用malloc函数申请一片连续的存储空间L->length = 0;L->MaxSize = InitSize;
}//增加动态数组的长度
void Increasesize(seqList* L, int len)
{int* p = L->data;L->data = (int*)malloc((L->MaxSize + len) * sizeof(int));for (int i = 0; i < L->length; i++){L->data[i] = p[i];}L->MaxSize = L->MaxSize + len; free(p);
}// 插入元素
int InsertList(seqList* L, int index, ElemType elem) {if (index < 0 || index > L->length || L->length == L->MaxSize) {return 0; // index error 或 溢出 }for (int i = L->length; i >= index; i--) {L->data[i + 1] = L->data[i]; // 后移一位 }L->data[index] = elem; // 插入新元素 L->length++; // 长度加一 return 1; // 插入成功
}// 删除元素
int DeleteList(seqList* L, int index) {if (index < 0 || index >= L->length) {return 0; // index error }for (int i = index; i < L->length - 1; i++) {L->data[i] = L->data[i + 1]; // 前移一位 }L->length--; // 长度减一 return 1; // 删除成功
}// 查找元素,返回元素位置,未找到返回-1
int FindList(seqList* L, ElemType elem) {for (int i = 0; i < L->length; i++) {if (L->data[i] == elem) {return i; // 找到元素,返回位置 }}return -1; // 未找到元素,返回-1
}// 修改元素,返回修改结果,未找到返回-1
int UpdateList(seqList* L, int index, ElemType elem) {if (index < 0 || index >= L->length) {return 0; // index error }L->data[index] = elem; // 修改元素值 return 1; // 修改成功,返回1
}
1.3 顺序表的特点
①随机访问,即可以在O(1)时间内找到第i个元素。
②存储密度高,每个节点只存储数据元素
③拓展容量不方便(即便采用动态分配的方式实现,拓展长度的时间复杂度也比较高)
④插入、删除操作不方便,需要移动大量元素
1.4顺序表的应用场景
顺序表适用于需要随机访问元素的场景,例如需要快速查找某个元素的位置或者根据下标进行访问。
以下是顺序表的一些应用场景举例:
- 数组:数组是一种顺序表的实现方式,适用于需要快速访问元素的场景,例如存储图像、音频等数据。
- 数据库:数据库中的表可以使用顺序表来实现,例如需要根据主键快速查找某个记录。
- 缓存:缓存中的数据可以使用顺序表来实现,例如需要快速查找某个缓存项。
- 索引:索引可以使用顺序表来实现,例如需要快速查找某个关键字对应的记录。
- 排序:排序算法中的一些算法可以使用顺序表来实现,例如冒泡排序、快速排序等。
~~更多 线性表相关知识 欢迎浏览下一篇文章《数据结构——线性表②》
相关文章:

数据结构——线性表①(顺序表)
一、线性表定义 线性表是一种数据结构,它是由n个具有相同数据类型的数据元素a1,a2,…,an组成的有限序列。 其中,除第一个元素a1外,每一个元素有且只有一个直接前驱元素,除了最后一个元素an外,每一个元素有且只有一个…...

MFC网络编程-Udp客户端
目录 1、UI的设计: 2、代码的实现: (1)、重写CSocket虚函数OnReceive,并且传入对话框的指针 (2)、初始化SOCKET (3)、绑定本地IP和端口 (4)、…...

密码学基础
密码学总览 信息安全面临的危险与应对这些威胁的密码技术: 关于上图中的威胁,这里在简单的说明: 窃听:指的是需要保密的消息被第三方获取。篡改:指的是消息的内容被第三方修改,达到欺骗的效果。伪装&…...

[Docker]四.Docker部署nodejs项目,部署Mysql,部署Redis,部署Mongodb
一.部署nodejs项目,映射端口,挂载数据卷 可以到https://hub.docker.com/去搜索node镜像,然后下载,也可以直接通过docker pull node下载镜像,然后用这个node镜像启动容器node,这样系统就集成了node服务了,在这里挂载www/node目录到容器中,并指定端口映射,运行nodejs程序,安装npm…...

拥抱AI-ChatGPT:人类新纪元
最近大模型通用智能应用持续发酵,各大科技公司都陆续推出了基于通用大模型的智能应用产品,典型的如OpenAI的ChatGPT、微软的BingChat、百度的文心一言、360的智脑、阿里的通义千问等。当然最火的要属于ChatGPT了,从去年年底推出到现在已经有很…...

基于深度学习的人脸表情识别 计算机竞赛
文章目录 0 前言1 技术介绍1.1 技术概括1.2 目前表情识别实现技术 2 实现效果3 深度学习表情识别实现过程3.1 网络架构3.2 数据3.3 实现流程3.4 部分实现代码 4 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 基于深度学习的人脸表情识别 该项目较…...

GitHub经常打不开或者访问解决办法
访问慢或无法访问的原因:DNS解析是最为基础的一个环节。由于Github的服务器在全球各地,域名解析所需的时间也会不同,这就导致了在特定地区可能会出现Github无法正常访问的情况。 解决:查询到github对应的IP,然后在host…...

密码学 - SHA-2
实验八 SHA-2 1.实验目的 熟悉SHA – 2算法的运行过程,能够使用C语言编写实现SHA-2算法程序,增加对摘要函数的理解。 2、实验任务 (1)理解SHA-2轮函数的定义和常量的定义。 (2)利用VC语言实现SHA-2算…...
Vins-Fusion、Vins-Mono(之前那个编译通过但是没有这个好用)
ROS的catkin_make不要修改,暂时没有理由,理由就是两次一个改了一个没改,没改的成功了以成功为准。 另外docker也没用成功,原本的逻辑来说,docker肯定不能出问题的,但是由于roscore通信的原因可能没有将结果显示&#x…...

每日自动化提交git
目前这个功能,有个前提: 这个git代码仓库,是一个人负责,所以不存在冲突问题 我这个仓库地址下载后的本地路径是:D:\Projects\Tasks 然后我在另外一个地方新建了一个bat文件: bat文件所在目录为:…...

【Linux进程】再谈软件—操作系统(Operator System)
目录 操作系统(Operator System) 概念 设计OS的目的 如何理解 "管理"——先描述再组织 系统调用和库函数概念 总结 操作系统(Operator System) 概念 任何计算机系统都包含一个基本的程序集合,称为操作系统(OS)。 笼统的理解,操作系统…...

创建超过1G内存大小的程序
正常情况一个进程最大占用内存为1G一下,如果程序有需求要使用超过1G大小的程序,可进行如下操作 VS修改设置:属性--->链接器--->系统--->启用大地址 【选择是】 测试申请堆内存代码 #include <stdlib.h> #include <stdio…...

如何本地部署Jellyfin影音服务器并实现在公网访问
文章目录 1. 前言2. Jellyfin服务网站搭建2.1. Jellyfin下载和安装2.2. Jellyfin网页测试 3.本地网页发布3.1 cpolar的安装和注册3.2 Cpolar云端设置3.3 Cpolar本地设置 4.公网访问测试5. 结语 1. 前言 随着移动智能设备的普及,各种各样的使用需求也被开发出来&…...
docker fixuid
docker fixuid 一、fixuid是什么二、使用场景三、问题dockerfiledocker run 一、fixuid是什么 fixuid是用go语言编写的,当容器起来后可以修改容器中非root用户的UID/GID和文件权限。 项目地址:https://github.com/boxboat/fixuid 二、使用场景 当容器…...

MySQL笔记--SQL语句
目录 1--SQL的通用语法 2--SQL语句的分类 3--DDL语句 3-1--数据库操作 3-2--表操作 3-3--数据类型 3-4--修改和删除 4--DML语句 4-1--插入数据 4-2--修改数据 4-3--删除数据 5--DQL语句 5-1--基本查询 5-2--条件查询 5-3--聚合函数 5-4--分组查询 5-5--排序查…...

线扫相机DALSA-相机平场矫正详细步骤
在相机视野下铺放白色亚克力板或纯白纸,采集图像。打开曲线图。 选择 Line Profile 模式。调节好相应所需的曝光时间、光源、增益和镜头光圈,让白平衡纸显示出来的灰度值大概在 150-200 左右。 在Calibration Algorithm 中将显示的数值设置好。 先暗场…...

求购供应发布农业副业产品市场行情小程序开发
农业副业产品求购供应发布市场行情小程序H5开源版开发 后台同步:一键获取全国近200家农产品批发市场的商品价格,包括蔬菜、水果、水产、粮油和农副产品等。 实时更新和同步市场价格动态,保障信息的准确性和时效性。 前端VIP权益功能&…...

框架安全-CVE 复现SpringStrutsLaravelThinkPHP漏洞复现
目录 服务攻防-框架安全&CVE 复现&Spring&Struts&Laravel&ThinkPHP概述PHP-开发框架安全-Thinkphp&Laravel漏洞复现Thinkphp-3.X RCEThinkphp-5.X RCELaravel框架安全问题- CVE-2021-3129 RCE JAVAWEB-开发框架安全-Spring&Struts2Struts2框架安全…...

【腾讯云 HAI域探秘】宝妈也能快速入门AI绘画
活动背景 本次活动是由腾讯云和CSDN联合推出的开发者技术实践活动。我通过技术交流直播、动手实验、征文等形式,深入沉浸式体验腾讯云高性能应用服务 HAI。从活动中汲取到技术上的精华。在本次活动中,只要完成各个环节任务,不仅可以参与 AIGC…...
归并排序,自顶向下
归并排序主要两步,一步是划分区间,另一步是合并两个区间 这个算法的稳定性更好,对比快排这种,如果整体是倒序的话,快排的复杂度会达到o(n^2),归并会更稳定。 划分区间主要是递归去实现,下面给…...

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...
<6>-MySQL表的增删查改
目录 一,create(创建表) 二,retrieve(查询表) 1,select列 2,where条件 三,update(更新表) 四,delete(删除表…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...

Python实现prophet 理论及参数优化
文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候,写过一篇简单实现,后期随着对该模型的深入研究,本次记录涉及到prophet 的公式以及参数调优,从公式可以更直观…...

Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
【算法训练营Day07】字符串part1
文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接:344. 反转字符串 双指针法,两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...

HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...

令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...

使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台
🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...

算法笔记2
1.字符串拼接最好用StringBuilder,不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...