04 什么是线性表

news2025/1/23 6:21:00

什么是线性表

一、为什么需要线性表

例如:

​ 在程序中保存指定班级的所有的学生信息(暂时只需要处理姓名、年龄),该班级最多可容纳30人,且可进行数量上的增减。

业务功能:

​ 1)这个项目中需要处理的对象是什么:学生

​ 2)需要存储多少个这样的对象:30

​ 3)其他的要求:人数可增可减

​ 项目中涉及学生信息,根据需求,目前学生所包含的属性只有姓名、年龄:

typedef struct _student
{
    // 姓名
    char name[20];
    // 年龄
    int age;
} STUDENT;

​ 需求中要存储一个班的学生,学生人数在 30 以内,所以可以使用数组为容器来解决该问题:

在这里插入图片描述

​ 要求可以对数组进行增减操作:

在这里插入图片描述

二、线性表的定义

​ 线性结构的应用:

​ 食堂排队打饭

​ 上课时老师按照点名表进行点名

​ 使用搜索引擎查询信息

​ 打牌时牌的摆放

​ ​ ……

线性表:0个或多个数据特性相同的元素构成的有限序列。

​ 线性表中数据元素的个数定义为线性表的长度,如果长度为0,则称其为空表

​ 一个非空的线性表,具有以下特点:

​ ​ ①存在唯一的一个被称作"第一个"的数据元素

​ ​ ②存在唯一的一个被称作“最后一个"的数据元素

​ ​ ③除第一个之外,结构中的每个数据元素都只有一个前驱

​ ​ ④除最后一个外,结构中的每个数据元素都只有一个后继

三、线性表的抽象数据类型

​ 线性表的操作

​ 创建线性表

​ 插入元素

​ 删除元素

​ 搜索元素

​ . . .

ADT 线性表{
数据对象:D={ai | ai∈ElemSet, i=1,2,…n,n≥0}
数据关系:S={<ai-1,ai> | ai-1,ai∈D,i=2,,n}
基本操作:
    init_list(*list)
        操作结果:初始化线性表
    get_length(list)
        初始条件:线性表list已存在
        操作结果:返回线性表的长度
    is_empty(list)
        初始条件:线性表list已存在
        操作结果:若list为空则返回1,否则返回0
    show(list)
        初始条件:线性表list已存在
        操作结果:对线性表list进行遍历
    get(list, i, *e)
        初始条件:线性表list已存在,且1 ≤ i ≤ get_length(list)
        操作结果:用e返回list中第i个元素的值
    insert(*list, i, e)
        初始条件:线性表已存在,且1 ≤ i ≤ get_length(list)+1
        操作结果:在list中第i个位置插入新的数据元素e,list的长度加1
    delete(*list, i)
        初始条件:线性表已存在,且1 ≤ i ≤ get_length(list)
        操作结果:删除list中的第i个数据元素,list的长度减1
    update(*list, i, e)
        初始条件:线性表已存在,且1 ≤ i ≤ get_length(list)
        操作结果:将list中第i个数据元素的值修改为e
    search(list, i, e)
        初始条件:线性表已存在,且1 ≤ i ≤ get_length(list)
        操作结果:从list中的第i个元素开始往后查找元素e,并返回第一次找到时的位置,未找到则返回0
}ADT 线性表

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2210261.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【分布式架构】分布式锁Redission

一、流程图 二、lua脚本实现原理 由setnxexpire实现 setnx&#xff1a;判断key是否存在&#xff0c;如果不存在&#xff0c;则获取锁 setnx的数据结构&#xff1a;<key,<key1,value>> key&#xff1a;业务声明的key key1&#xff1a;线程id value&#xff1a;次数…

css 翻页效果

有一个项目&#xff0c;页面切换的时候要翻页效果。 所以有一个简单的demo&#xff0c;提供给大家学习 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdev…

Golang | Leetcode Golang题解之第476题数字的补数

题目&#xff1a; 题解&#xff1a; func findComplement(num int) int {highBit : 0for i : 1; i < 30; i {if num < 1<<i {break}highBit i}mask : 1<<(highBit1) - 1return num ^ mask }

空间计算:现实与数字世界的无缝融合

随着增强现实&#xff08;AR&#xff09;、虚拟现实&#xff08;VR&#xff09;、物联网&#xff08;IoT&#xff09;和人工智能&#xff08;AI&#xff09;的不断进步&#xff0c;空间计算&#xff08;Spatial Computing&#xff09;作为一种新兴技术&#xff0c;正在成为人们…

IDEA Sping Boot 多配置文件application Maven动态切换

新建application-dev.yml与application-prod.yml pom.xml文件下添加profiles等 让idea识别出配置文件 <profiles><profile><id>dev</id><properties><!-- 环境标识&#xff0c;需要与配置文件的名称相对应 --><profiles.active>dev&…

安装和配置k8s可视化UI界面dashboard-1.20.6

安装和配置k8s可视化UI界面dashboard-1.20.6 1.环境规划2.初始化服务器1&#xff09;配置主机名2&#xff09;设置IP为静态IP3&#xff09;关闭selinux4&#xff09;配置主机hosts文件5&#xff09;配置服务器之间免密登录6&#xff09;关闭交换分区swap&#xff0c;提升性能7&…

2013年国赛高教杯数学建模A题车道被占用对城市道路通行能力的影响解题全过程文档及程序

2013年国赛高教杯数学建模 A题 车道被占用对城市道路通行能力的影响 车道被占用是指因交通事故、路边停车、占道施工等因素&#xff0c;导致车道或道路横断面通行能力在单位时间内降低的现象。由于城市道路具有交通流密度大、连续性强等特点&#xff0c;一条车道被占用&#x…

ubuntu22.04 ROS2 - 安装

参考链接:Ubuntu 22.04 LTS安装ROS2 (ros-humble-desktop)-CSDN博客 1、安装测试 ros2 run demo_nodes_cpp listener再开一个终端ros2 run demo_nodes_cpp listener2、小海龟模拟器 ros2 run turtlesim turtlesim_noderos2 run turtlesim turtle_teleop_key两个终端分别执行…

树莓派应用--AI项目实战篇来啦-5.OpenCV绘画函数的使用

1. 介绍 OpenCV作为一款功能强大的计算机视觉库&#xff0c;被广泛地应用于图像处理和计算机视觉领域。 除了在机器视觉和人工智能领域有者广泛的应用&#xff0c;OpenCV 还能够媲美艺术家的创造力&#xff0c;通过其强大的绘图函数&#xff0c;绘制出令人叹为观止的艺术画作。…

【ICESat-2(Ice, Cloud and land Elevation Satellite-2)简介】

ICESat-2&#xff08;Ice, Cloud and land Elevation Satellite-2&#xff09;&#xff0c;即冰、云和陆地高程卫星2号&#xff0c;是美国国家航空航天局&#xff08;NASA&#xff09;的一项重要卫星任务&#xff0c;旨在测量地球冰盖、云层以及陆地的高度变化。以下是对ICESat…

phpstorm+phpstudy 配置xdebug(无需开启浏览器扩展)

今天又被xdebug折磨了&#xff0c;忘记了以前咋配置了现在百度发现好多都是各种浏览器扩展而且也没有真正的用到项目上的都是测试的地址怎么样的 我就简单写一下自己实战吧 不支持workerman swoole hyperf等这种服务框架 如果你会请教教我 工具版本phpstudy8.1.xphpstorm2021.x…

用SpringBoot给Servlet容器Tomcat打war包步骤

首先写一个类来代替启动类 先在SpringBoot项目里打开pom.xml导入依赖,原本SpringBoot里面spring-boot-starter-web依赖里面有Tomcat,所以我们要先在spring-boot-starter-web里面导入依赖,把Tomcat给排除掉,并且加上你要打的war类型依赖 然后先刷新,再清除,最后再打包 成功之后,…

华为云Flexus云服务:性能倍增、体验跃级

在数字化转型的浪潮中&#xff0c;企业对云计算的需求日益增长&#xff0c;尤其是在性能和体验方面。华为云Flexus云服务应运而生&#xff0c;为企业提供了一个性能倍增、体验跃级的云计算解决方案。下面九河云就来给大家介绍一下华为云Flexus云服务吧。 1. 性能倍增 华为云…

【AI绘画】Midjourney进阶:三分线构图详解

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AI绘画 | Midjourney 文章目录 &#x1f4af;前言&#x1f4af;什么是构图为什么Midjourney要使用构图 &#x1f4af;三分线构图特点使用场景提示词书写技巧测试 &#x1f4af;小结 &#x1f4af;前言 【AI绘画】Midjourney进阶&a…

cmake 报错及解决

1.背景&#xff1a;自己编写CMakeLists.txt并构建项目 2.问题&#xff1a;build目录下执行“cmake ..”命的时候如下报错&#xff1a; CMake Error at CMakeLists.txt:27 (ADD_EXECUTABLE): The target name "client," is reserved or not valid for certain CMak…

FlexMatch: Boosting Semi-Supervised Learning with Curriculum Pseudo Labeling

FlexMatch: Boosting Semi-Supervised Learning with Curriculum Pseudo Labeling 摘要:引言:背景3 flexMatch3.1 Curriculum Pseudo Labeling3.2 阈值预热3.3非线性映射函数实验4.1 主要结果4.2 ImageNet上的结果4.3收敛速度加速4.4 消融研究5 相关工作摘要: 最近提出的Fi…

MaxKB 三大内置标签用法

一、<quick_question> <quick_question></quick_question> 作用&#xff1a;快速展示问题标签&#xff0c;只需将问题放入标签中&#xff0c;系统便会自动在对话结束时展示该问题。 1.1 展示效果 1.2 快捷使用 在流程编排当中&#xff0c;添加一个AI对话…

线性代数 矩阵

一、矩阵基础 1、定义 一组数按照矩形排列而成的数表&#xff1b;形似行列式&#xff0c;区别点是 矩阵行列式符号()或[]| |形状方阵或非方阵方阵本质数表数属性A|A|是A诸多属性中的一种维度m *n (m 与n可以相等也可以不相等)n*n 同型矩阵 若A、B两个矩阵都是mn 矩阵&#x…

【Elasticsearch系列】Elasticsearch启动失败问题

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

【JavaEE初阶】文件-IO之实现文件系统的操作如何进行实现

前言 &#x1f31f;&#x1f31f;本期讲解关于文件IO的操作&#xff0c;这里涉及到比较常用的文件操作哦~~~ &#x1f308;上期博客在这里&#xff1a;【JavaEE初阶】CAS的ABA问题&#xff0c;JUC多线程编程有用的相关类-CSDN博客 &#x1f308;感兴趣的小伙伴看一看小编主页&a…