数据结构实验报告

article/2025/10/4 18:36:01

数据结构与算法实验一(顺序表的操作)

一、实验目的

1.掌握线性表的顺序存储结构的表示和实现方法。
2.掌握顺序表基本操作的算法实现。
3.了解顺序表的应用。

二、实验内容

1.建立顺序表。
2.在顺序表上实现插入、删除和查找操作(验证性内容)。
3.删除有序顺序表中的重复元素(设计性内容)。
4.完成一个简单学生成绩管理系统的设计(应用性设计内容)。

三、实验的软硬件环境要求

硬件环境要求:
PC机(单机)
使用的软件名称、版本号以及模块:
Windows环境下的VC++等。

四、知识准备

前期要求熟练掌握了C语言的编程规则、方法和顺序表的基本操作算法。

五、验证性实验

1.实验要求

编程实现如下功能:
(1)根据输入顺序表的长度n和各个数据元素值建立一个顺序表,并输出顺序表中各元素值,观察输入的内容与输出的内容是否一致。
(2)在顺序表的第i个元素之前插入一个值为x的元素,并输出插入后的顺序表中各元素值。
(3)删除顺序表中第i个元素,并输出删除后的顺序表中各元素值。
(4)在顺序表中查找第i个元素,如果查找成功,则显示“查找成功”和该元素在顺序表中的位置,否则显示“查找失败”。

2. 实验相关原理:

线性表的顺序存储结构称为顺序表,顺序表的存储结构描述为:

#define MAXLEN  30  /*线性表的最大长度*/
typedef struct 
{   Elemtype  elem[MAXLEN]; /*顺序表中存放元素的数组,其中elemtype为抽象数据类型,在程序具体实现时可以用任意类型代替*/int length;   /*顺序表的长度,即元素个数*/}Sqlist;   /*顺序表的类型*/

【核心算法提示】
1.顺序表插入操作的基本步骤:要在顺序表中的第i个数据元素之前插入一个数据元素x,首先要判断插入位置i是否合法,假设线性表的表长为n,则i的合法值范围:1≤i≤n+1,若是合法位置,就再判断顺序表是否满,如果满,则增加空间或结束操作,如果不满,则将第i个数据元素及其之后的所有数据元素都后移一个位置,此时第i个位置已经腾空,再将待插入的数据元素x插入到该位置上,最后将线性表的表长增加1。
2.顺序表删除操作的基本步骤:要删除顺序表中的第i个数据元素,首先仍然要判断i的合法性,i 的合法范围是1≤i≤n,若是合法位置,则将第i个数据元素之后的所有数据元素都前移一个位置,最后将线性表的表长减1。
3.顺序表查找操作的基本步骤:要在顺序表中查找一个给定值的数据元素,则可以采用顺序查找的方法,从顺序表中第1个数据元素开始依次将数据元素值与给定值进行比较,若相等则返回该数据元素在顺序表中的位置,否则返回0值。
【核心算法描述】

status Sqlist_insert(Sqlist &L,int i,Elemtype x)/*在顺序表L中第i个元素前插入新元素x*/
{ if (i<1||i>L.length+1) return ERROR; /*插入位置不正确则出错*/if (L.length>=MAXLEN)  return OVERFLOW; 
/*顺序表L中已放满元素,再做插入操作则溢出*/for(j=L.length-1;j>=i-1;j--)L.elem[j+1]=L.elem[j];/*将第i个元素及后续元素位置向后移一位*/L.elem[i-1]=x;   /*在第i个元素位置处插入新元素x*/L.length++;    /*顺序表L的长度加1*/return OK;}
status Sqlist_delete(Sqlist &L,int i,Elemtype &e)/*在顺序表L中删除第i个元素*/
{ if (i<1||i>L.length)  return ERROR; /*删除位置不正确则出错*/
for(j=i;j<=L.length-1;j++) L.elem[j-1]=L.elem[j]; /*将第i+1个元素及后继元素位置向前移一位*/L.length--;   /*顺序表L的长度减1*/return OK; }
int Sqlist_search(Sqlist L,Elemtype x)/* 在顺序表中查找值为x的元素,如果找到,则函数返回该元素在顺序表中的位置,否则返回0*/
{ for (i=0;i<L.length&&L.elem[i]!=x;i++);
/*从第一个元素开始依次将每个元素值与给定值x比较*/if (i<L.length)return  i;else return  o;
}

3.学生实验代码

#include "stdio.h"
#define MaxSize 50typedef struct node{int elem [MaxSize];int length;}Sqlist;Sqlist creat(Sqlist L,int n){int i=0;for(i=0;i<n;i++){int x;printf("请输入值:");scanf("%d",&x);L.elem [i]=x;}L.length =n;return L;}void print(Sqlist L){for(int i=0;i<L.length;i++)printf("%4d",L.elem [i]);printf("\n");}Sqlist Sqlist_insert(Sqlist L,int i,int x){if(i<1||i>L.length )printf("error");if(L.length >=MaxSize)printf("overflow");for(int j=L.length-1;j>=i-1;j--)L.elem [j+1]=L.elem [j];L.elem [i-1]=x;L.length++;return L;}
Sqlist Sqlist_delete(Sqlist &L,int i,int e)
{if(i<1||i>L.length )printf("error");
//		if(L.length >=MaxSize)
//		printf("overflow");for(int j=i;j<=L.length-1;j++)L.elem [j-1]=L.elem [j];L.length--;return L;
}
int Sqlist_search(Sqlist L,int x)
{int i;for(i=0;i<L.length&&L.elem [i]!=x;++i);if(i<L.length )return i;elsereturn -1;
}
int main()
{Sqlist head;int n,k,i,x;printf("请输入n的值:");scanf("%d",&n);head=creat(head,n);print(head);printf("请输入插入i位置的值:");scanf("%d",&i);printf("请输入要插入x的值:");scanf("%d",&x);head=Sqlist_insert(head,i,x);print(head);printf("请输入要删除的i位置的值:");scanf("%d",&i);head=Sqlist_delete(head,i,x);print(head);printf("请输入要查找的值:");scanf("%d",&x);k=Sqlist_search(head,x);if(k==-1)printf("NOT found\n");else printf("要查找的%d在%d位置上",x,k+1);return 0;
}

4.运行结果

在这里插入图片描述

六、设计性实验(以下两个设计题目学生可根据自己的掌握程度或兴趣自行选择完成)

1.编程实现删除有序顺序表中的所有重复元素,即使有序顺序表中相同的元素只保留一个。

⑴ 实验要求
① 根据输入的n个非递减的有序数据建立一个有序顺序表,并输出有序顺序表中各元素值。
② 删除有序顺序表中所有的重复元素,并显示删除后的有序顺序表中各元素值。
⑵ 核心算法提示

要在有序顺序表中删除重复的元素,首先就要抓住有序顺序表的特性:重复的元素总是在相邻的位置上,如:12,15,15,15,35,56,56,78。则删除重复元素后所得的有序表为:12,15,35,56,78。下面给出大致的操作步骤:从第1个元素开始,依次将它与后面相邻的元素进行比较,如果相等则将前面那个相等的元素从顺序表中删除;如果不相等,则继续往下比较,如此重复,直到最后一个元素为止。

⑶ 核心算法描述
   Sqlist delSqlist(Sqlist L)
{int i=0,j;while(i<L.length-1)if (L.elem[i]==L.elem[i+1])   /*如果第i个及第i+1个相邻元素值相等*/{ for (j=i+1;j<L.length;j++)   /*将第i+1个元素及其之后的所有元素前移一个位地置,以达到删除第i个元素的目的*/L.elem[j-1]=L.elem[j];L.length--;        /*有序顺序表的表长减1*/}elsei++;return L;
}

2.编程实现一个简单学生成绩表的操作。
实验要求
此系统的功能包括:
① 查询:按特定的条件查找学生
② 修改:按学号对某个学生的某门课程成绩进行修改
③ 插入:增加新学生的信息
④ 删除:按学号删除已退学的学生的信息。
学生成绩表的数据如下:
学号 姓名 性别 大学英语 高等数学
2008001 Alan F 93 88
2008002 Danie M 75 69
2008003 Helen M 56 77
2008004 Bill F 87 90
2008006 Peter M 79 86
2008006 Amy F 68 75
要求采用顺序存储结构来实现对上述成绩表的相关操作。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STR_LEN 20
#define MAX_STUDENT_NUM 10
typedef struct student{int id;char name[7];char sex[5];int English;int Math;
}STUDENT;
int Insert(STUDENT student[],int num);
void PrintLine(STUDENT student[],int num);
int Search(STUDENT student[],int student_id);
int Delete(STUDENT student[],int student_id);
int main(void){STUDENT a[MAX_STUDENT_NUM];int res,num,student_id;int command;while(1){printf("%s","1.插入学生信息\n2.删除学生信息\n3.查询学生信息\n4.显示学生信息\n5.exit\n");scanf("%d",&command);printf("\n");fflush(stdin);switch(command){case 1:printf("输出学生人数:");scanf("%d",&num);fflush(stdin);if(num>MAX_STUDENT_NUM){printf("Exceeds the maximum\n");continue;}res=Insert(a,num);if(res==2){printf("success!\n");}else{printf("false!\n");}break;case 2:printf("输入学生学号:");scanf("%d",&student_id);fflush(stdin);res=Search(a,student_id);if(res==-1){printf("the student is not exist\n");}else{Delete(a,res);num=num-1;}break;case 3:printf("输入查询的学号:");scanf("%d",&student_id);fflush(stdin);res=Search(a,student_id);if(res==-1){printf("the student is not exist\n");}else{printf("学号     姓名         性别         大学英语         大学数学\n");printf("%d%9s%9s%17d%17d\n",a[res-1].id ,a[res-1].name ,a[res-1].sex,a[res-1].English,a[res-1].Math);}break;case 4:PrintLine(a,num);break;case 5:return 0;default :printf("input error!\n");break;}}return 0;}
int Insert(STUDENT student[],int num){int i;int res;for(i=0;i<=num-1;i++){printf("input the student id:");res=scanf("%d",&student[i].id);fflush(stdin);if(res==0){printf("error!input again:");res=scanf("%d",&student[i].id);}printf("input the student name:");scanf("%s",&student[i].name);printf("input the student sex:");scanf("%s",&student[i].sex);printf("input the student English:");scanf("%d",&student[i].English);printf("input the student Math:");scanf("%d",&student[i].Math);printf("已录入!\n");fflush(stdin);if(res==0){printf("error!input again\n");res=scanf("%d",&student[i].id);}}return 2;
}void PrintLine(STUDENT student[],int num){int i;if(num==0){printf("the student array is null\n");}else{printf("学号     姓名         性别         大学英语         大学数学\n");for(i=0;i<num;i++){printf("%d%9s%9s%17d%17d",student[i].id ,student[i].name ,student[i].sex,student[i].English,student[i].Math);printf("\n");}}
}
int Search(STUDENT student[],int student_id){int i;for(i=0;i<=MAX_STUDENT_NUM;i++){if(student[i].id==student_id){return i+1;}}return -1;
}int Delete(STUDENT student[],int student_id){int j;for(j=student_id;j<=MAX_STUDENT_NUM;j++){student[j-1].id=student[j].id;strcpy(student[j-1].name,student[j].name);strcpy(student[j-1].sex,student[j].sex);student[j-1].English=student[j].English;student[j-1].Math=student[j].Math;}printf("success!\n");return 1;
}

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

相关文章

【数据结构】实验项目:顺序表,也就那么回事

目录 序 嗨&#xff0c;这里是狐狸~~ 简介 顺序表的结构定义&#xff1a; 声明顺序表类型变量&#xff1a; 实验内容&#xff1a; 实验说明 : 实验思路 1、 输入一组整型元素序列&#xff08;不少于10个&#xff09;&#xff0c;建立顺序表。 2&#xff0e; 在该顺…

数据结构(实验一)

第一次写报告&#xff0c;虽然有点简单&#xff0c;但还是要勉励自己再接再厉。加油 继续努力。 1.实验目的&#xff08;结出本次实验所涉及并要求掌握的知识点&#xff09; 1.掌握顺序表的存储结构形式及描述方法和基本运算的实现&#xff1b; 2.掌握用顺序表设计合理的数据…

数据结构实验

1.有序数组的插入 代码&#xff1a; bool Insert( List L, ElementType X ){//溢出if(L->LastMAXSIZE-1) return false;//插入在最后一位if(L->Data[L->Last] > X){L->Data[L->Last1]X;L->Last;return true;}int tp0;int find0;int tmp0;for(int i0;i &l…

网络传输大文件使用什么软件可以高速传输?

网络传输大文件使用什么软件可以高速传输&#xff1f;通过网络传输文件总是在速度上得不到很好的体现&#xff0c;更不用说是传输大文件了。本身支持大文件网络传输的工具就是不是很多&#xff0c;很多的传输工具对文件的大小都有所限制&#xff0c;要是想要找到一个高速传输大…

.mmap文件用什么软件可以打开?

1.下载MindManager专属打开它的软件 2。

什么是Saas软件?

人们常常会提及Saas&#xff08;萨斯&#xff09;软件&#xff0c;那么什么是Saas软件呢&#xff1f;首先大家通过百度可以看到百度百科的解释 相信大多数的伙伴们看了之后的感想就是一脸蒙圈&#xff0c;如果让自己给别人介绍什么是Saas软件还是记不住解释不清楚&#xff0c;那…

测试移动信号频率的软件,手机信号工作频段侦测软件

手机信号来源于基站发射的信号。但是常常会遇见的手机信号差&#xff0c;信号弱&#xff0c;上网速度慢等&#xff0c;都有可能是源于信号弱带来的。那么我们看见的手机上显示的信号弱&#xff0c;到底是什么信号弱&#xff1f;如何判别&#xff1f; 这里推荐一款APP软件&#…

杀毒软件可以查杀所有计算机病毒吗,杀毒软件可以查杀所有病毒吗

杀毒软件包括电脑杀毒软件和手机杀毒软件&#xff0c;那么杀毒软件可以查杀所有病毒吗&#xff1f;目前&#xff0c;做到所有病毒查杀还没有一家杀毒软件敢100%保证&#xff0c;因为电脑病毒也在日新月异的发展着&#xff0c;那是不是新病毒就查杀不了呢&#xff1f;也不是&…

可以测试电脑网络速度的软件,介绍4种有用的Internet Speed软件应用程序,用于测试网络速度软件...

当今社会将使用Internet&#xff0c;但是Internet的速度极大地影响了我们的工作和浏览. 在玩游戏和观看视频时测网速什么软件好&#xff0c;拥有一个良好的Internet甚至更为必要. 目前&#xff0c;我们可以使用Internet速度测试软件进行测试. 网络的速度和稳定性使您可以更好地…

什么软件可以测试鬼,PP助手新奇App推荐 《鬼魂探测器》能抓鬼?

最近&#xff0c;小伙伴们迷上了一款奇葩App&#xff0c;据说可以将潜伏在你周围的“阿飘”揪出来。这款软件就是《鬼魂探测器》&#xff0c;听起来是不是有点毛骨悚然&#xff0c;但又忍不住好奇心&#xff0c;通过PP助手下载一探究竟吧。 图1&#xff1a;PP助手(Win)2.0 只要…

测试电脑整机功耗软件,有什么好的测电脑整机功耗的软件吗?

很多人都说电脑的速度越快耗电量就越快&#xff0c;早期的486和现在的P4相比&#xff0c;那简直就是“节能电脑”了&#xff0c;那么想不想知道你的电脑到底有耗电量是多少呢&#xff1f;来试试Overclockulator吧&#xff0c;根据你的选择它可以估算出一台电脑的耗电量。 该软件…

有没有测试颜色的软件,用什么软件测试显示器色彩最准:色彩校正软件

用什么软件测试显示器色彩最准&#xff1a;1.iphone直接显示器校色&#xff0c;这个估计是最有效的方法。有的人可能用不惯iphone的界面&#xff0c;我经常用iphone来测试工程数据&#xff0c;因为iphone有自己的屏幕校色传感器&#xff0c;而iphone的屏幕比一般的显示器都要准…

java用什么软件_Java编程什么软件最好用?

原标题&#xff1a;Java编程什么软件最好用&#xff1f; “工欲善其事必先利其器”&#xff0c;想要学好Java编程开发&#xff0c;除了要有好的学习资源之外&#xff0c;还要有一套适合自己的Java编程软件&#xff0c;好的编程软件能极大提高你的学习和工作效率。那么&#xff…

kml用什么软件打开?

下载安装 bigemap GIS office软件&#xff08;免费就可以) 2、 安装好下载的bigemap软件&#xff0c;直接将kml kmz拖到软件里面就打开了&#xff0c;或者左上角文件打开 选择 kml/kmz 然后选择你的文件 打开记性了。 BIGEMAP支持所有文件格式的打开和保存&#xff0c;如…

可以测试英语发音的软件,检测英语发音的软件

目录 一、音标软件 ①.同求!!!和外国人多说说话。 ②.百度里打“朗酷口语”就可以了~~ 这 个软件可以的!俺也用~~~ 哈哈祝你好运~~。 ③.你好,你说的就跟复读机是一个道理。这种软件不过就是对于人的音频和关键点做了一个发音的匹配度测试,语音库会先前录好没一个单词的发…

测试显卡用什么软件最好,显卡测试用什么软件 怎么测试显卡性能

如果要精确的测试一块显卡的性能则需要一款专业的显卡测试软件,显卡测试用什么软件?像3dmark 11、built-in benchmark tool、gpu-z等软件都是相当优秀的显卡测试软件,另外的测试就是烤机了,可以利用furmark软件烤机测试显卡性能。今天小编就为大家介绍显卡测试的方法。 什么…

有什么软件可以直接拒接所有骚扰电话?3款App让你不再为骚扰电话烦恼

现在大部分智能手机都有自带的拦截功能&#xff0c;可以自动标记可疑的来电号码、对垃圾短信也能起到拦截作用。如果你的手机没有这种功能&#xff0c;也可以下载第三方安全软件进行拦截。 熊猫吃短信app&#xff1a;点击左侧链接下载 熊猫吃短信app是一款值得推荐的垃圾短信过…

什么软件专业测试电脑,测验电脑性能 用什么软件

方法/步骤 1.首先说说电脑的第一个检测&#xff1a;硬件检测&#xff0c;其核心是CPU和GPU(也就是处理器和显卡)。 2.为什么需要这款软件呢&#xff0c;其实在笔记本里这款软件用处不是特别大&#xff0c;因为笔记本配置其实相对很死板(但是硬件详细信息还是有用的&#xff0c;…

有什么软件可以免费下载歌曲?99%不知道这3款软件!

有什么软件可以免费下载歌曲&#xff1f;我们都知道&#xff0c;网络上现在大多数主流音乐软件或手机APP现在都有版权收费限制&#xff0c;在这里推荐几款比较好用的手机端的App和电脑端的一款播放器及下载歌曲的网站。 音乐狂&#xff1a;点击左侧链接下载 音乐狂是一款优秀的…

有什么软件可以提升视频画质,将模糊视频修复清晰?

在素材录制或图像采集过程中&#xff0c;由于各种不可抗拒的因素&#xff0c;画面可能会出现模糊。我们应该如何处理&#xff1f;如何将模糊的视频修复清晰呢&#xff1f; 或许大家在生活中有注意到在各大短视频平台上&#xff0c;哪些经典影视剧修复版的重映屡屡刷屏&#xf…