【数据结构】线性表的顺序存储结构及实现——C语言版

article/2025/9/23 7:18:09

在这里插入图片描述
在这里插入图片描述

文章目录

    • 顺序表
    • 1. 顺序表的存储结构定义
    • 2. 顺序表的实现
      • 2.1 初始化顺序表
      • 2.2 建立顺序表
      • 2.3 销毁顺序表
      • 2.4 判空操作
      • 2.5 求顺序表的长度
      • 2.6 遍历操作
      • 2.7 按值查找
      • 2.8 按位查找
      • 2.9 插入操作
      • 2.10 删除操作
    • 3. 顺序表的使用
    • 4. 暖暖树洞

在这里插入图片描述

顺序表

线性表的顺序存储结构称为顺序表,其基本思想是用一段地址连续的存储单元一次存储线性表的数据元素。

设顺序表的每个元素占用 c 个存储单元,则第 i 个元素的存储地址为:

所以,只要确定了存储顺序表的起始地址(即基地址),计算任意一个元素的存储地址的时间是相等的。

我们通常用一维数组来实现顺序表,也就是把线性表中相邻的元素存储在数组中相邻的位置,从而导致数据元素的序号和存放它的数组下标之间具有一一对应的关系。

注意: \color{RoyalBlue}注意: 注意:
C语言中数组的下标是 从0开始 的,而顺序表中元素的序号是 从1开始 的,即线性表中第 i 个元素存储在数组中下标为 i-1 的位置。

定义一个数组必须确定数组的长度。由于线性表中可以进行插入操作,所以数组长度要大于当前线性表的长度。MaxSize表示数组长度,用length表示线性表的长度。

在这里插入图片描述

1. 顺序表的存储结构定义

#define MaxSize 100  //假设顺序表最多存放100个元素
typedef int DataType;	//定义线性表的数据类型,假设为int型typedef struct
{DataType data[MaxSize];	//存放数据元素的数组int length;	//线性表的长度
}SeqList;

在这里插入图片描述

2. 顺序表的实现

2.1 初始化顺序表

初始化顺序表只需要将顺序表的长度length初始化为0,

void InitList(SeqList* L)
{L->length = 0;
}

2.2 建立顺序表

建立一个长度为n的顺序表,需要将给定的数据元素传入顺序表中,并将传入的元素个数作为顺序表的长度。

设给定的数据元素存放在数组a[n]中,建立顺序表的操作如图:

函数CreatList的返回值表示建立顺序表操作是否成功,如果顺序表的存储空间小于给定数据元素个数,则无法建立顺序表。

int CreatList(SeqList* L, DataType a[], int n)
{if (n > MaxSize){printf("顺序表的存储空间不够,无法建立顺序表\n");return 0;}for (int i = 0; i < n; i++){L->data[i] = a[i];}L->length = n;return 1;
}

2.3 销毁顺序表

顺序表是静态存储分配,在顺序表变量退出作用域时,自动释放该变量所占内存单元。因此,顺序表无须销毁。

2.4 判空操作

顺序表的判空操作只需要判断长度length是否为0就可以了,

int Empty(SeqList* L)
{if (L->length == 0) {return 1;	//顺序表为空返回1}else{return 0;}
}

2.5 求顺序表的长度

int Length(SeqList* L)
{return L->length;
}

2.6 遍历操作

在顺序表中,遍历操作即是按下标依次输出各元素

void PrintList(SeqList* L)
{for (int i = 0; i < L->length; i++){printf("%d ", L->data[i]);	//输出线性表的元素值,假设为int型}
}

2.7 按值查找

在顺序表中实现按值查找操作,需要对顺序表中的元素依次进行比较,如果查找成功,返回元素的序号(注意不是下标),否则返回0

int Locate(SeqList* L, DataType x)
{for (int i = 0; i < L->length; i++){if (L->data[i] == x){return i + 1;	//返回序号}}return 0;	//循环结束,说明查找失败
}

2.8 按位查找

顺序表中第i个元素存储在数组中下标为i-1的位置,
所以,很容易实现按位查找。

函数Get的返回值表示是否查找成功,若查找成功,通过指针参数ptr返回查找到的元素值。

int Get(SeqList* L, int i, DataType* ptr)
{if (i<1 || i>L->length){printf("查找位置非法,查找失败\n");return 0;}else{*ptr = L->data[i - 1];return 1;}
}

2.9 插入操作

插入操作是在表的第i(1≦i≦n+1)个位置进行插入新元素x,使长度为n的线性表变成了长度为n+1的线性表。

注意: \color{RoyalBlue}注意: 注意:
元素移动的方向,是从最后一个元素开始移动,直至将第i个元素后移为止,然后将新元素插入i处。如果表满,则引发上溢错误,如果元素的插入位置不合法,则引发位置错误。

int Insert(SeqList* L, int i, DataType x)
{if (L->length >= MaxSize){printf("上溢错误,插入失败");return 0;}if (i<1 || i>L->length + 1){printf("位置错误,插入失败");return 0;}for (int j = L->length; j >= i; j--){L->data[j] = L->data[j - 1];}L->data[i - 1] = x;L->length++;return 1;
}

2.10 删除操作

删除操作是将表的第i(1≦i≦n)个元素删除,使长度为n的线性表变成了长度为n-1的线性表。

注意: \color{RoyalBlue}注意: 注意:
元素移动的方向,是从第 i+1 个元素(下标为i)开始移动,直至将最后一个元素前移为止,并且在移动元素之前取出被删元素。如果表空,则引发下溢错误,如果元素的删除位置不合理,则引发位置错误。

int Delete(SeqList* L, int i, DataType* ptr)
{if (L->length == 0){printf("下溢错误,删除失败\n");return 0;}if (i<1 || i>L->length){printf("位置错误,删除失败\n");return 0;}*ptr = L->data[i - 1];	//取出位置i的元素for (int j = i ; j < L->length; j++){L->data[j - 1] = L->data[j];}L->length--;return 1;
}

在这里插入图片描述

3. 顺序表的使用

#include<stdio.h>
#include<stdlib.h>
/*将顺序表的存储结构定义和各个函数定义放到这里*/int main()
{int r[5] = { 1,2,3,4,5 }, i, x;SeqList L;	//定义变量L为顺序表类型CreatList(&L, r, 5);	//建立具有5个元素的顺序表printf("当前线性表的数据为:");PrintList(&L);	//输出当前线性表 1 2 3 4 5Insert(&L, 2, 8);	//在第2个位置插入值为8的元素printf("插入之后的数据为:");PrintList(&L);	//输出插入后的线性表 1 8 2 3 4 5printf("当前线性表的长度为:%d\n", Length(&L));	//输出线性表的长度6printf("请输入查找的元素值:");scanf("%d", &x);i = Locate(&L, x);if (i == 0){printf("查找失败\n");}else{printf("元素%d的位置为:%d\n", x, i);}printf("请输入查找第几个元素的值:");scanf("%d", &i);if (Get(&L, i, &x) == 1){printf("第%d个元素的值为:%d\n", i, x);}else{printf("线性表中没有第%d个位置元素\n",i);}printf("请输入要删除第几个元素:");scanf("%d", &i);if (Delete(&L, i, &x) == 1){printf("删除成功,删除的数据为%d\n", x);}else{printf("删除操作失败\n");}return 0;
}

在这里插入图片描述

4. 暖暖树洞

“要留点精力去读书去运动去爱人,去奔赴想要的生活,不应该把精力浪费在痛苦的社交讨厌的人那里,看起来可以挽回的事情,仔细想想一点都不值得,贪恋过去的快乐注定走不远,过去的就让它过去吧,在热爱生活的同时快乐的小事情真的很多很多。”


http://chatgpt.dhexx.cn/article/4YRpepVS.shtml

相关文章

VUE activated,deactivated使用

项目中keepalive用得不多&#xff0c;记录一下以免遗忘。 页面第一次进入&#xff0c;钩子的触发顺序created-> mounted-> activated&#xff0c;退出时触发deactivated。当再次进入&#xff08;前进或者后退&#xff09;时&#xff0c;只触发activated。 事件挂载的方…

vue activated,deactivated生命周期的使用

1.当组件在 内被切换&#xff0c;它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。 2.activated()&#xff1a;在vue对象存活的情况下&#xff0c;进入当前存在activated()函数的页面时&#xff0c;一进入页面就触发&#xff1b;可用于初始化页面数据等…

vue 中 keep-alive,activated,deactivated

keep-alive 在组件反复切换时&#xff0c;会反复渲染&#xff0c;造成性能问题。用一个 <keep-alive></keep-alive> 标签将他包裹起来&#xff0c;组件会在第一次被创建的时候缓存下来。避免性能问题。 首先准备好组件&#xff0c;配置好路由。准备了Home,Keep,Abo…

【Vue】学习笔记-Vue Router activated deactivated 路由守卫

Vue Router activated deactivated 路由守卫 activated deactivated路由守卫1.全局守卫2.独享守卫3.组件内守卫全局路由守卫路由器的两种工作模式 activated deactivated activated 和 deactivated 是路由组件所独有的两个钩子&#xff0c;用于捕获路由组件的激活状态 具体使用…

vue 生命周期图 + activated + deactivated

一、vue 生命周期图 From the network 二、activated deactivated 除此之外&#xff0c;简单介绍一下在被keep-alive包含的组件/路由中&#xff0c;会多出两个生命周期的钩子:activated 与 deactivated。在 2.2.0 及其更高版本中&#xff0c;activated 和 deactivated 将会…

[Vue]缓存路由组件 activated()与deactivated()

前言 系列文章目录&#xff1a; [Vue]目录 老师的课件笔记&#xff0c;不含视频 https://www.aliyundrive.com/s/B8sDe5u56BU 笔记在线版&#xff1a; https://note.youdao.com/s/5vP46EPC 视频&#xff1a;尚硅谷Vue2.0Vue3.0全套教程丨vuejs从入门到精通 文章目录 前言1. 缓存…

Vue 钩子函数activated未触发

activated()和deactivated()只有在<keep-alive></keep-alive>包裹的时候才有效&#xff1b;

搞明白activated和deactivated

文章目录 写到前面什么是activatedactivated解决了一个什么问题Demomain.vueassembly1(组件1)assembly2(组件2) 执行结果要点速记个人建议写到最后 写到前面 今天简单的将activated讲一下&#xff0c;前面有人问了&#xff0c;既然有问的&#xff0c;说明还有人不是很明白的&am…

vue中activated

keep-alive <keep-alive>包裹动态组件的时候&#xff0c;会缓存不活动的组件实例&#xff0c;而不是摧毁他们。其是一个抽象的组件&#xff0c;自身不会渲染一个DOM元素&#xff0c;也不会出现在父组件链中。 说白了被<keep-alive>包裹的组件其会被缓存。 没有被…

Vue学习之---动态组件中的activated与deactivated钩子函数

Vue学习之—动态组件中的activated与deactivated钩子函数 在学习这两个钩子函数之前呢&#xff0c;怎么需要先了解下Vue内置的动态组件< component >以及与之相配套的< keep-alive > 组件&#xff1a; 动态组件指的是动态切换组件的显示与隐藏&#xff1b; < …

vue中keep-alive、activated的探讨和使用

在修改公司的一个项目的时候发现了activated这个东西&#xff0c;一直觉得很疑惑&#xff0c;之前也没怎么用过啊&#xff01;官网的生命周期那也没说过这东西啊&#xff01;生命周期不就create mount update 和destory这几个东东么&#xff0c;怎么多了个activate出来。 百思不…

html页面ajax提交数据,ajax请求提交form表单

AJAX表单提交以及数据接收 方式一 手工收集所有的用户输入&#xff0c;封装为大的“k1v1&k2v2…”键值对形式&#xff0c;使用$.post(url, data,fn)把数据提交给服务器 $.ajax({ type:post, url:Notice_noTipsNotice, data:k1v1&k2v2..., cache:false, dataType:json, …

接上篇 jquery.form.js 的 $.ajaxForm()和 $.ajaxSubmit()

2019独角兽企业重金招聘Python工程师标准>>> AjaxSubmit 和AjaxForm区别 AjaxForm ajaxForm()不能提交表单。在document的ready函数中&#xff0c;使用ajaxForm来为AJAX提交表单进行准备。提交动作必须由submit开始 , ajaxForm()适用于以表单提交方式处理ajax技术&a…

springboot ajax form json 请求方式

1.form请求的后台代码 1.定义实体 Student package com.bsx.test.entity;import com.bsx.test.constant.Gender; import com.bsx.test.constant.Nature;import javax.persistence.Column; import javax.persistence.Id; import javax.persistence.Table; import java.io.Seri…

ajax form表单提交 input file中的文件

现今的主流浏览器由于ajax提交form表单无法把文件类型数据提交到后台&#xff0c;供后台处理&#xff0c;可是开发中由于某些原因又不得不用ajax提交文件&#xff0c; 为了解决这个问题我走了不少弯路&#xff1a; 1、用原生的 input file &#xff0c; 不支持ajax上传文件&…

Jquery 中 ajaxSubmit 、ajaxForm使用讲解

最近在使用ajaxForm&#xff0c;随便把使用方法记下下来&#xff0c;以便以后回顾。 1 &#xff0c;引入依赖脚本 <script type"text/JavaScript" src"/js/jQuery/jquery.form.js"></script> //ajaxForm 依赖脚本 <script type"…

ajaxForm 与ajaxSubmit

ajaxSubmit 和ajaxForm区别 ajaxForm ajaxForm()不能提交表单。在document的ready函数中&#xff0c;使用ajaxForm来为AJAX提交表单进行准备。提交动作必须由submit开始 ajaxForm()适用于以表单提交方式处理ajax技术&#xff08;需要提供表单的action、id、 method&#xff0…

前后端交互之使用ajax方法实现form表单的提交

转载于&#xff1a;使用ajax方法实现form表单的提交 - 程序员十三 - 博客园 (cnblogs.com) οnsubmit“reutrn false”&#xff1a;表示禁止表单提交。 data: $(#addTaskform).serialize(),序列化提交表单数据。 不要忘记引用js文件 <script type"text/javascript&…

一文必懂-Ajax与form

Restful与Ajax Ajax示例1:查询所有学生数据示例2&#xff1a;查找部分学生数据中文传参 表单标签抓包数据 Post与GetRestful示例Restful附带URL参数 Ajax与form标签 Ajax 一种在网页上调用后台接口的方式 jquery提供了相应的用法 即 $.ajax({内容});先添加jQuery包。 内容部分…

手把手教你开发一款属于自己的Arduino开发板

【前言】 相信很多小伙伴们手里都一块或者几块开发板吧&#xff0c;没有没想过自己也开发一款开发板呢&#xff1f;接下来就教你开发一款属于自己的开发板吧(●◡●)。 【软件版本】 AD17 【正文】 1. 硬件选型 1.1 主控芯片&#xff1a;用ATMEGA32P吧&#xff0c;用LQFP封…