数据结构——线性表①(顺序表)
一、线性表定义
线性表是一种数据结构,它是由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),归并会更稳定。 划分区间主要是递归去实现,下面给…...
idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...
Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)
引言:为什么 Eureka 依然是存量系统的核心? 尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...
EtherNet/IP转DeviceNet协议网关详解
一,设备主要功能 疆鸿智能JH-DVN-EIP本产品是自主研发的一款EtherNet/IP从站功能的通讯网关。该产品主要功能是连接DeviceNet总线和EtherNet/IP网络,本网关连接到EtherNet/IP总线中做为从站使用,连接到DeviceNet总线中做为从站使用。 在自动…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
华硕a豆14 Air香氛版,美学与科技的馨香融合
在快节奏的现代生活中,我们渴望一个能激发创想、愉悦感官的工作与生活伙伴,它不仅是冰冷的科技工具,更能触动我们内心深处的细腻情感。正是在这样的期许下,华硕a豆14 Air香氛版翩然而至,它以一种前所未有的方式&#x…...
代码随想录刷题day30
1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...
【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...
