顺序表基本操作的实现

article/2025/9/14 21:45:25

实验一 顺序表基本操作的实现

一、实验学时: 2学时

二、实验目的

  • 实现顺序表的基本操作

三、实验内容

  1. 顺序表的建立、取指定元素、返回指定元素位置
  2. 顺序表中插入新元素、删除指定元素操作的实现

四、主要仪器设备及耗材

  • 硬件:计算机一台
  • 软件:VC++ 6.0,MSDN2003或者以上版本

五、实验步骤

  1. 分析问题
  2. 写出算法
  3. 编制程序
  4. 上机调试
  5. 分析结果

六、程序清单

#include<stdio.h>
#include<string.h>
#include<stdlib.h>			//要用exit所以加它 
#define OK 1				//成功返回值 
#define ERROR 0         	//出错返回值 
#define OVERFLOW -2    		//溢出返回值 
#define MAXSIZE 10000   	//空间大小 
//用户自定义类型Status 
typedef int Status;//定义图书结构体 
typedef struct
{char no[20];		//书号 char name[50];		//书名 float price;		//价格 
}Book;//用户自定义类型SqList 
typedef struct
{Book *elem;		//图书指针 int length;		//图书顺序表长度 
}SqList;//初始化顺序表 
Status InitList(SqList &L)		//形参要的是SqList的引用,调用时是InitList(L),因为引用更改后它本身就更改了。不然传的只是副本,对原值无影响。 
{L.elem=new Book[MAXSIZE];	//为顺序表分配一个MAXSIZE大小的数组空间 if(!L.elem) exit(OVERFLOW);	//分配失败退出 L.length=0;					//空表长度为0 return OK;
}//取值 
Book GetElem(SqList L,int i)	//取出顺序表位于第i个位置的元素 
{if(i<1||i>L.length) printf("取值操作异常");	//取值异常 return L.elem[i-1];							//返回找到的值 
}//查找 
int LocateElem(SqList L,Book e)		//查找元素e在顺序表中的位置 
{int i;for(i=0;i<L.length;i++)if(strcmp(L.elem[i].no,e.no)==0&&strcmp(L.elem[i].name,e.name)==0&&L.elem[i].price==e.price) return i+1;return 0;
}//插入 
Status ListInsert(SqList &L,int i,Book e)	//将元素e插入到顺序表L的第i的位置 
{if((i<1)||(i>L.length+1)) return ERROR;if(L.length==MAXSIZE) return ERROR;int j;for(j=L.length-1;j>=i-1;j--)L.elem[j+1]=L.elem[j];				//i位置及以后的元素整体后移 L.elem[i-1]=e;++L.length;return OK;
}//删除 
SqList ListDelete(SqList &L,int i)
{if((i<1)||(i>L.length+1)) printf("删除异常");int j; for(j=i;j<=L.length-1;j++)L.elem[j-1]=L.elem[j];				//被删元素后面的整体前移 --L.length;return L;
}int main()
{SqList L;Status status = InitList(L);if(!status){printf("顺序表初始化失败!\n");return ERROR;	}else{printf("顺序表初始化成功!\n");Book e;printf("请录入图书信息:\n");printf("书号:");scanf("%s",&e.no);printf("书名:");scanf("%s",&e.name);printf("价格:");scanf("%f",&e.price);int i;for(i=1;;++i){ListInsert(L,i,e);printf("成功收藏%d本书至图书馆\n",i);printf("书号:");scanf("%s",&e.no);printf("书名:");scanf("%s",&e.name);printf("价格:");scanf("%f",&e.price);if(e.price==0)break;}printf("图书馆共%d本书\n",L.length);printf("图书馆的图书列表:\n");Book e1;int j;printf("编号\t书名\t\t价格\n");for(j=1;j<=L.length;j++){e1=GetElem(L,j);printf("%s\t",e1.no);printf("%s\t",e1.name);printf("%-7.2f\n",e1.price);}Book e2={"10102","计算机组成原理",46.5};int location = LocateElem(L,e2);printf("其中第%s在第%d个位置\n",e2.name,location); printf("------------------------------\n"); printf("删除第二本后的列表:\n"); SqList sl = ListDelete(L,2);printf("图书馆共%d本书\n",sl.length);printf("图书馆的图书列表:\n");printf("编号\t书名\t\t价格\n");for(j=1;j<=sl.length;j++){e2=GetElem(sl,j);printf("%s\t",e2.no);printf("%s\t",e2.name);printf("%-7.2f\n",e2.price);}}
}

七、运行结果及分析
当价格为0结束输入
八、小总结

  • 建立顺序表(初始化):初始化就是用指针指向新分配的空间,若内存不足分配失败则退出,否的话长度置为0,然后返回OK。
  • 取指定位置元素(取值):就是超出范围取值异常,在范围内就返回第i个元素。
  • 返回指定元素位置(查找):循环查找,如果是基本数据类型相等就行了,像本程序中用的是Book结构体类型,所以要比较每一个数据,都相等则返回位置。
  • 向指定位置插入元素(插入):超出范围和溢出都报错,i位置及以后的元素整体后移空出位置i放元素e,然后长度加1。
  • 删除指定位置元素(删除):超出范围报错,否则被删元素后面的元素整体前移,长度减1。
  • 要说的问题:&L与L
    参数里的这两者区别,带&是传的引用,可以更改L里的数据,不然的话只是传了一个副本,形参改变对实参无影响。

http://chatgpt.dhexx.cn/article/JOGEWAjW.shtml

相关文章

数据结构学习笔记——顺序表的基本操作(超详细最终版+++)建议反复看看ヾ(≧▽≦*)o

目录 前言一、顺序表的相关知识点二、顺序表的定义三、顺序表的初始化四、顺序表的建立五、顺序表的输出六、顺序表的逆序输出七、顺序表的插入操作八、顺序表的删除操作九、顺序表的按位和按值查找基本操作的完整代码十*、顺序表删除的常用操作十一*、顺序表的常用合并操作 前…

数据结构:顺序表的基本操作

线性表的顺序存储顺序表的线性存储示意图C语言定义线性表的顺序存储结构顺序表的基本操作顺序表的基础操作完整代码 线性表的顺序存储 线性表的顺序存储是指用一组地址连续的存储单元依次存储线性表中的各个元素&#xff0c;使得线性表在逻辑结构上相邻的元素存储在连续的物…

顺序表的基本操作(C语言)

1.要求 编程实现顺序表的基本操作&#xff0c;并设计一个菜单调用。 ①建立&#xff08;初始化&#xff09;、遍历、取值、查找、插入、删除 ②判空、求元素个数、前驱、后继、置为空表、销毁 2.分析 我们需要去定义一个结构体&#xff08;以下代码的结构体名为SqList),其…

C语言实现顺序表基本操作

1.顺序表初始化 2.顺序表创建 3.求顺序表的长度 4.判断顺序表是否为空 5.向顺序表中插入元素 6.删除顺序表中元素 7.将顺序表翻转 8.将顺序表降序排序 #include<stdio.h> #define MAXSIZE 100//定义顺序表的最大存储个数 typedef struct SqList {int *base;int l…

顺序表基本操作

文章目录 1. 顺序表插入元素2. 顺序表删除元素3. 顺序表查找元素4. 顺序表更改元素 1. 顺序表插入元素 向顺序表中插入数据元素&#xff0c;根据插入位置的不同&#xff0c;可分为以下 3 种情况&#xff1a; 插入到顺序表的表头&#xff1b;在表的中间位置插入元素&#xff1…

顺序表的基本操作

一、实验目的&#xff1a; 1、复习C语言程序设计中的知识。 2、掌握线性表的顺序存储结构的表示和实现方法。 3、掌握顺序表基本操作的算法实现。 二、实验内容&#xff1a; 1&#xff0e;建立顺序表。 2&#xff0e;在顺序表上实现插入、删除和查找等操作。 三、实验要求…

数据结构-顺序表基本操作的实现(含全部代码)

今天起开始编写数据结构中的各种数据结构及其算法的实现。 主要依据严蔚敏版数据结构教材以及王道数据结构考研辅导书。 今天是线性表中的顺序表的实现&#xff0c;主要实现函数如下&#xff0c;读者有需要可以评论&#xff0c;我可以适当加几个。 CreateList(SqList &L…

PTA题目:顺序表基本操作

实现顺序表的基本操作&#xff0c;如初始化、插入、删除、输出等。 注意&#xff1a;顺序表中可有重复元素值。 要求&#xff1a;写出三个基本操作函数ListInsert&#xff0c;ListDelete&#xff0c;ListDeleteElem。 顺序表结构与操作函数接口定义&#xff1a; typedef char…

顺序表的操作,你真的学会了吗?

&#x1f30d;新人小白的博客 ⌛️希望大家多多关注 &#x1f383;以后会经常更新哒~&#x1f648; ⭐️个人主页&#xff1a; 收藏加关注&#xff0c;永远不迷路~ ⭐️ 顺序表的操作 前言一、目的二、步骤1.定义存储表示2. 定义操作函数3.采用菜单样式让操作更加方便清楚。4. …

数据结构——顺序表的基本操作

目录 1.顺序表的定义 2.define和typedef 3.以下所有用到函数的声明 4.建表&#xff0c;为表开放空间 5.建表&#xff0c;并且输入表内的值 6.在L中第i个位置之前查人新的数据元素e&#xff0c;L的长度加1 7.删除L的第i个数据元素&#xff0c;并用e返回其值&#xff0c;L的…

顺序表基本操作算法——基础代码(C语言)

创建一个顺序表&#xff08;数据元素个数为5&#xff09;&#xff0c; 输出顺序表中的所有数据元素 查找第3个位置上的元素 查找元素15是否在顺序表中&#xff0c;如果在&#xff0c;请输出该元素在顺序表中的位置 在顺序表中的第1个位置插入数据0 删除刚刚插入的元素 输出顺序…

顺序表的十个基本操作(全)

目录 一、初始化顺序表 二、插入 三、删除 3.1 按位删除 3.2 按数删除 四、查找 4.1 按位查找 4.2 按数查找 五、修改 5.1 按位修改 5.2 按数修改 六、逆置 七、排序 八、按序插入 九、按序合并 十、最小值 完整代码 一、初始化顺序表 初始化并一个顺序表&am…

数据结构—顺序表基本操作的实现(C语言)

前言 本文介绍线性表顺序存储时基本操作的实现&#xff0c;包括顺序表的结构定义、初始化、插入、删除、销毁、显示、清空、判空、求长度、查找&#xff0c;以及线性表的合并。 主要参考&#xff1a;严蔚敏“数据结构及应用算法教程”教材 代码如下 #include <stdio.h>…

顺序表的基本操作(超详细)

1.顺序表的定义 使用结构体来构造一个顺序表。 typedef struct {int length;//当前顺序表长度int Maxsize;//顺序表最大长度int* data;//定义顺序表中元素类型的数组指针 }SqList;2.顺序表的初始化 顺序表的初始化是使用动态分配数组空间方式构造一个空的线性表。 #include&…

多组比较的非参数检验——K-W检验

作者&#xff1a;丁点helper 来源&#xff1a;丁点帮你 前面我们已经讲完两组比较的非参数检验&#xff0c;类似t检验与方差分析&#xff0c;当比较的数据超过两组时&#xff0c;我们就需要换一个方法了。 非参数K-W检验&#xff0c;相比前文讲解的Mann-Whitney 检验就是这样…

推断统计:参数估计和假设检验

目录 1、总体、个体、样本和样本容量    1&#xff09;总体、个体、样本和样本容量的概念    2&#xff09;本文章使用的相关python库   2、推断统计的概念    1&#xff09;推断统计的概念    2&#xff09;为什么要进行推断统计&#xff1f;   3、参数估计(点…

非参数检验之符号检验、Wilcoxon符号秩检验、游程检验

目录 一、符号检验 例2.1下面是世界上71个大城市的花费指数(包括租金)按递增次序排列如下(这里上海是44位&#xff0c;其指数为63.5&#xff09;&#xff1a; R代码&#xff1a; 二、Wilcoxon符号秩检验 例2.3下面是10个欧洲城镇每人每年平均消费的酒类相当于纯酒精数&…

SPSS非参数检验

系列文章目录 SPSS描述统计 SPSS均值检验 SPSS方差分析 文章目录 系列文章目录前言1 非参数检验提出的背景与特点1.1 背景1.2 特点 2 SPSS分析-非参数检验菜单中的相关功能2.1 卡方检验2.1.1 概述2.1.2 操作流程2.1.3 实例操作 2.2 二项分布检验2.2.1 概述2.2.2 操作流程2.2.3…

入门必学 | R语言参数检验之t检验与方差分析

T检验与方差分析 背景介绍R语言实操过程--t test单样本t检验两个独立样本t检验配对t检验 R语言实操过程--anova单因素方差分析多重比较 双因素方差分析 完整代码 之前与大家分享了数据的独立性、正态性、方差齐性检验。如果还不清楚&#xff0c;大家可以通过这篇推文来学习和理…

R语言对数据进行非参数检验

假设检验&#xff1a;参数检验运用样本的统计量来估计总体的参数&#xff0c;如用样本均值估计总体均值&#xff0c;用样本标准差估计总体标准差。 非参数检验则不考虑数据的具体值&#xff0c;而更多地运用了数据大小排序的信息&#xff0c;因此不可能以此估计总体的参数 1.原…