实现顺序表各种基本运算的算法

news2025/1/15 17:27:04

实验一:实现顺序表各种基本运算的算法

一、实验目的与要求

目的:

领会顺序表存储结构和掌握顺序表中各种基本运算算法设计。

内容:

编写一个程序sqlist.cpp,实现顺序表的各种基本运算和整体建表算法(假设顺序表的元素类型ElemType为char),并在此基础上设计一个主程序,完成如下功能:

(1)初始化顺序表L。

(2)依次插入a、b、c、d、e元素。

(3)输出顺序表L。

(4)输出顺序表L长度

(5)判断顺序表工是否为空。

(6)输出顺序表工的第3个元素

(7)输出元素a的位置。

(8)在第4个元素位置上插入f元素

(9)输出顺序表工。

(10)删除顺序表L的第3个元素。

(11)输出顺序表工。

(12)释放顺序表工。

二、实验类型

C++算法编程

三、实验原理及说明

线性表的顺序存储结构是把线性表中的所有元素按照其逻辑顺序依次存储到从计算机存储器中指定存储位置开始的一块连续的存储空间中,线性表的顺序存储结构简称为顺序表(sequentiallist)。

在C++语言中,数组可以满足顺序表的存储结构,所以我们使用C++语言进行编程,实现线性表的顺序存储结构

四、实验主要仪器设备和材料

序 号

名 称

主要用途

1

电脑

打开软件

2

Dev c++

编写代码,运行代码

五、实验内容和步骤

根据《教程》中2.2节的算法得到sqlist.cpp程序,其中包含如下函数。

InitList(SqList *&L):初始化顺序表L。

DestroyList(SqList *L):释放顺序表。

ListEmpty(SqList *L):判断顺序表L是否为空表

ListLength(SqList *L):返回顺序表的元素个数。

DispList(SqList *L):输出顺序表L。

。GetElem(SqList *L,inti,ElemType&e):获取顺序表L中第i个元素LocateElem(SqList *L,ElemTypee):在顺序表L中查找元素e。

ListInsert(SqList *&L,inti,ElemTypee):在顺序表L中第i个位置上插入元素e。

ListDelete(SqList *&L,inti,ElemType &e):从顺序表L中删除第i个元素。

对应的程序代码如下(设计思路详见代码中的注释):

步骤:

创建一个sqList.cpp文件,将函数写入文件中

创建一个main.cpp文件,编写主函数,对函数进行验证

实验内容:

1.编写sqList.cpp

#include <iostream>

using namespace std;



#define MaxSize 50                                          //线性表最大长度

typedef char ElemType;                                  //定义类型

typedef struct {                                         //定义数据结构

        ElemType data[MaxSize];                       //存元素

        int length;                                                  //长度

} SqList;





//整体建立顺序表

void CreateListR(SqList *&L, ElemType a[],int n) {

        L = new SqList;                                        //为L分配空间

        for (int i = 0; i < n; i ++) {

                 L->data[i] = a[i];

        }

        L->length = n;

}



//初始化顺序表

void InitList(SqList *&L) {

        L = new SqList;

        L->length = 0;

}

//释放顺序表

void DestroyList(SqList *&L) {

        delete L;

}

//判断顺序表是否为空

bool ListEmpty(SqList *L) {

        return (L->length == 0);

}

//返回顺序表L的元素个数

int ListLength(SqList *L) {

        return (L->length);

}

//输出顺序表L

void DispList(SqList *L) {

        for (int i= 0; i < L->length; i++) {

                 cout << L->data[i] << " ";

        }

        cout << endl;

}

//求线性表中的第i个元素值

bool GetElem(SqList *L, int i , ElemType &e) {

        if (i < 1 || i > L->length)

                 return false;

        e = L->data[i - 1];

        return true;

}

//在顺序表L中查找元素e

int LocateElem(SqList *L, ElemType e) {

        int i = 0;

        while (i < L->length && L->data[i] != e) {

                 i++;

        }

        if (i >= L->length) {

                 return 0;

        }

        else return i + 1;

}

//在顺序表L中第i个位置上插入元素e.

bool ListInsert(SqList *&L, int i, ElemType e) {

        int j;

        if (i < 1 || i > L->length + 1) {

                 return false;

        }

        i--;

        for (j = L->length; j > i; j--) {

                 L->data[j] = L->data[j - 1];

        }

        L->data[i] = e;

        L->length++;

        return true;

}

//从顺序表L中删除第i个元素

bool ListDelete(SqList *&L, int i, ElemType &e) {

        int j;

        if (i < 1 || i > L->length) {

                 return false;

        }

        for (int j = i - 1; j < L->length; j++) {

                 L->data[j] = L->data[j + 1];

        }

        L->length--;

        return true;

}

2.编写main.cpp

#include "sqList.cpp"



int main() {

        SqList *L;

        ElemType e;

        cout << "顺序表的基本运算如下:" << endl;

        cout << " (1)初始化顺序表L" << endl;

        InitList(L);

        cout << " (2)依次插入a,b,c,d,e元素" << endl;

        ListInsert(L, 1, 'a');

        ListInsert(L, 2, 'b');

        ListInsert(L, 3, 'c');

        ListInsert(L, 4, 'd');

        ListInsert(L, 5, 'e');

        cout << " (3)输出顺序表L:";

        DispList(L);

        cout << " (4)顺序表L长度:" << ListLength(L) << endl;

        cout << " (5)顺序表L为" << (ListEmpty(L) ? "空":"非空")<< endl;

        GetElem(L, 3, e);

        cout << " (6)顺序表L的第三个元素:" << e <<endl;

        cout << " (7)元素a的位置:" << LocateElem(L,'a') << endl;

        cout << " (8)在第四个元素位置上插入f元素" << endl;

        ListInsert(L, 4, 'f');

        cout << " (9)输出顺序表L:";

        DispList(L);

        cout << " (10)删除L的第三个元素" << endl;

        ListDelete(L, 3, e);

        cout << " (11)输出顺序表L:" ;

        DispList(L);

        cout << " (12)释放顺序表L" << endl;

        DestroyList(L);

        return 1;

}

运行结果:

六、实验小结与分析

此次实验通过实践的方法,实现了使用编程语言对顺序表的实现,顺序表直接将线性表的逻辑结构映射到存储结构上,既便于理解,又容易实现。使我了解了线性表的顺序存储结构在C++中如何实现的,使我对线性表的顺序存储结构更加了解。

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

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

相关文章

【免费】支持向量机回归预测(SVR)的MATLAB实现(含源代码)

支持向量机&#xff08;Support Vector Machine, SVM&#xff09;是一种常用于分类和回归分析的机器学习算法。虽然SVM最为人熟知的是其分类应用&#xff0c;但它同样适用于回归任务&#xff0c;被称为支持向量回归&#xff08;Support Vector Regression, SVR&#xff09;。以…

温故而知新-JUC篇【面试复习】

温故而知新-JUC篇【面试复习】 前言版权推荐温故而知新-JUC篇多线程Java语言中的线程安全线程安全的实现方法线程的创建线程的状态wait和sleep的区别ThreadLocalsynchronize的优化synchronize和Reentrant的对比AQS线程池ThreadPoolExecutorThreadPoolExecutor源码ConcurrentHas…

javaSwing电影票购票管理系统(视频+源码)

摘要 运行环境&#xff1a;jdk1.8 mysql5.7 eclipse 系统实现 联系 q:3996962787 完整代码、sql、报告、程序资源

【Shell脚本】文本三剑客之sed编辑器

目录 一.sed编辑器的相关介绍及执行过程 1.sed介绍 2.sed编辑器的执行过程 二.sed命令格式 1.基本格式 2.在一个脚本文件里定义操作命令 3.常用操作 三.打印功能 1.默认打印方式 2.防止出现重复打印 2.1. 2.2. 2.3. 2.4. 3.使用地址打印 3.1.以数字形式打印行区…

物联网实战--平台篇之(八)分组后台管理

目录 一、分组数据库 二、请求分组列表 三、添加分组 四、重命名分组 五、删除分组 六、分组排序 本项目的交流QQ群:701889554 物联网实战--入门篇https://blog.csdn.net/ypp240124016/category_12609773.html 物联网实战--驱动篇https://blog.csdn.net/ypp240124016/ca…

给你一把接口响应断言神器,你要不要?

JSON Schema是用来标记和校验JSON数据&#xff0c;类似于XMLSchema,可用在自动化测试验证JSON数据。 官网&#xff1a;http://json-schema.org/ 最常用版本&#xff1a;draft 04。&#xff08;目前各类编程语言对draft 04支持最广泛&#xff09; 举个例子 假如你有一个接口…

【LeetCode】【3】无重复字符的最长子串(1113字)

文章目录 [toc]题目描述样例输入输出与解释样例1样例2样例3 提示Python实现滑动窗口 个人主页&#xff1a;丷从心 系列专栏&#xff1a;LeetCode 刷题指南&#xff1a;LeetCode刷题指南 题目描述 给定一个字符串s&#xff0c;请你找出其中不含有重复字符的最长子串的长度 样…

element DatePicker 日期选择器设置禁用未来日期,时间范围为60天

需要用到 DatePicker 里面的 picker-options 方法 disabledDate onPick方法 <el-date-pickerv-model"form.xxxx"type"daterange"value-format"yyyy-MM-dd":clearable"false":picker-options"pickerOptions"start-placeho…

「React」2024最新版本入门 React 19 你需要掌握什么

前言 React 是前端很火且被广泛使用的一个框架&#xff0c;在当下这个时间想入门上手React开发&#xff0c;我们需要了解它的哪些最为关键的特性&#xff0c;本文将一一列出。 介绍 类组件在官方文档中也已经被废弃&#xff0c;下面均为 React Hooks useStateuseEffectuse…

C - Sigma Problem(AtCoder Beginner Contest 353)

题目的链接: C - Sigma Problem (atcoder.jp) 题目&#xff1a; 样例&#xff1a; 题目大致含意: 给你n个数&#xff0c;让你对这n个数进行操作&#xff0c;比如当前是第i个&#xff0c;那么让a[i] 和 后面的每个数进行相加, 例如a[i] a[i 1] 注意的是a[i] a[i 1]的结果…

ASTGCN 论文学习上

这里写自定义目录标题 Attention Based Spatial-Temporal Graph Convolutional Networks for Traffic Flow Forecasting1. 摘要1.1 背景1.2 现有方法的不足1.3 提出的方法1.3.1 方法细节 1.4 实验结果 2 引言2.1 研究背景2.2 问题描述2.3 数据基础2.4 现有方法及其局限性2.5 提…

Easy Notes 彩色记事本,备忘录,笔记本,尊享版 v1.2.42.0517

软件介绍 「Easy Notes」是一款为用户量身打造的简易记事本管理应用APP&#xff0c;其功能覆盖了笔记撰写、备忘录设置、彩色便签制作及加密文档存储等。该应用程序以简洁的界面和便捷的操作性为核心&#xff0c;为用户提供了一个多元化的记录体验。借助其彩色背景与分类清单的…

AI预测体彩排3采取878=23策略+杀断组+杀和尾+杀和值012缩水测试5月23日预测第8弹

最近几天单位事情比较多&#xff0c;回来会比较晚&#xff0c;等忙过这段时间后每天我会恢复到中午左右将预测结果发出来&#xff0c;望各位见谅~今天继续验证测试87823策略&#xff0c;继续完成一个周期&#xff08;十期&#xff09;的测试。下面直接发预测结果~ 首先…

网络模型-Qinq配置与应用

Qinq配置与应用 通过配置Qinq来实现利用公网提供的VLAN100使企业1互通&#xff0c;利用公网提供的VLAN200使企业2互通不同企业之间互相隔离。并通过在连接其它厂商设备的接口上配置修改0in0外层VLAN Tag的TPID值&#xff0c;来实现与其它厂商设备的互通。 一、创建VLAN #在Swi…

基于springboot+vue的学生考勤管理系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

【Linux】Centos7安装RabbitMQ

【Linux】Centos7安装RabbitMQ 下载 从 rabbitmq 的 GitHub 仓库下载 https://github.com/rabbitmq/rabbitmq-server/releases rabbitmq 是 erlang 语言编写的&#xff0c;需要先安装 erlang https://github.com/rabbitmq/erlang-rpm/releases 安装 使用rz命令上传 erlang 和 …

卡尔曼滤波(2):卡尔曼滤波与递归计算

1. 卡尔曼解决什么问题 比较经典的说法是&#xff0c;卡尔曼滤波适用于任何带有不确定性的系统中。那么我们怎么来理解这种不确定性呢&#xff1f;具体来讲&#xff0c;包含以下几种情况。 当前系统不存在完美的数学表达模型&#xff0c;即不能够通过一些数学方式来表达这个系…

智狐AI论文写作平:提升学术生产力的智能工具,支持私有化部署

在学术研究领域&#xff0c;人工智能&#xff08;AI&#xff09;技术的引入正逐渐改变传统的论文撰写流程。AI论文自动生成工具的出现&#xff0c;为研究人员提供了前所未有的便利与优势。以下是对AI论文自动生成工具带来的便利与优势的深度剖析和解读。 首先&#xff0c;AI论文…

c++设计模式-->访问者模式

#include <iostream> #include <string> #include <memory> using namespace std;class AbstractMember; // 前向声明// 行为基类 class AbstractAction { public:virtual void maleDoing(AbstractMember* member) 0;virtual void femaleDoing(AbstractMemb…

DFE_offset失调校准

1.校准原因 *制造工艺的限制&#xff1a;晶体管在制造过程中&#xff0c;由于工艺的限制&#xff0c;不可能做到完全对称&#xff0c;这导致了输入级晶体管的性能存在微小的差异。 *输入级偏置电流的不对称&#xff1a;输入级晶体管的偏置电流也会存在差异&#xff0c;这也会…