预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共15页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

..完美WORD格式专业整理知识分享淮海工学院计算机科学系实验报告书课程名:《数据结构》题目:线性表数据结构试验班级:软件112学号:姓名:评语:成绩:指导教师:批阅时间:年月日..线性表实验报告要求1目的与要求:1掌握线性表数据结构的基本概念和抽象数据类型描述;2熟练掌握线性表数据结构的顺序和链式存储存表示;3熟练掌握线性表顺序存储结构的基本操作算法实现;4熟练掌握线性表的链式存储结构的基本操作算法实现;5掌握线性表在实际问题中的应用和基本编程技巧;6按照实验题目要求独立正确地完成实验内容〔提交程序清单及相关实验数据与运行结果;7按照报告格式和内容要求,认真书写实验报告,并在试验后的第三天提交电子〔全班同学提交到学委,再统一打包提交给老师和纸质〔每班每次5份,学委安排,保证每个同学至少提交一次;8积极开展实验组组内交流和辅导,严禁复制和剽窃他人实验成果,一旦发现严肃处理;9上实验课前,要求每个同学基本写好程序,并存储在自己的U盘上,用于实验课堂操作时调试和运行。凡不做准备,没有提前编写程序者,拒绝上机试验。2实验内容或题目一、顺序表的基本操作实现实验要求:数据元素类型ElemType取整型int。按照顺序存储结构实现如下算法:1创建任意整数线性表〔即线性表的元素值随机在键盘上输入的顺序存储结构〔即顺序表,长度限定在25之内;2打印/显示〔遍历该线性表〔依次打印/显示出表中元素值;3在顺序表中查找第i个元素,并返回其值;4在顺序表第i个元素之前插入一已知元素;5在顺序表中删除第i个元素;6求顺序表中所有元素值〔整数之和;二、链表〔带头结点基本操作实验要求:数据元素类型ElemType取字符型char。按照动态单链表结构实现如下算法:1按照头插法或尾插法创建一个带头结点的字符型单链表〔链表的字符元素从键盘输入,长度限定在10之内;2打印〔遍历该链表〔依次打印出表中元素值,注意字符的输入顺序与链表的结点顺序;3在链表中查找第i个元素,i合法返回元素值,否则,返回FALSE;4在链表中查找与一已知字符相同的第一个结点,有则返回TRUE,否则,返回FALSE;5在链表中第i个结点之前插入一个新结点;6在线性表中删除第i个结点;7计算链表的长度。3实验步骤与源程序#include<iostream>#defineOK1#defineERROR0#defineTRUE1#defineFALSE0#defineElemTypeint#defineMAXSIZE25/*此处的宏定义常量表示线性表可能达到的最大长度*/usingnamespacestd;typedefstruct{ElemTypeelem[MAXSIZE];/*线性表占用的数组空间*/intlast;/*记录线性表中最后一个元素在数组elem[]中的位置〔下标值,空表置为-1*/}SeqList;voidOutputSeqList<SeqList*L>{cout<<"顺序表如下:"<<endl;inti;for<i=0;i<=L->last;i++>cout<<L->elem[i]<<'\n';cout<<endl;}intGetDate<SeqList*L>{intt;cout<<"请输入要查找的元素的序数:"<<endl;cin>>t;if<<t<0>||<t>L->last>>{cout<<"输入错误!";return<ERROR>;}elsereturn<L->elem[t-1]>;}intInsList<SeqList*L>{inti,e;cout<<"请输入要插入的元素插入位置及要插入的元素"<<endl;cin>>i>>e;intk;if<<i<1>||<i>L->last+2>>/*首先判断插入位置是否合法*/{printf<"插入位置i值不合法">;return<ERROR>;}if<L->last>=MAXSIZE-1>{printf<"表已满无法插入">;return<ERROR>;}for<k=L->last;k>=i-1;k-->/*为插入元素而移动位置*/L->elem[k+1]=L->elem[k];L->elem[i-1]=e;/*在C语言数组中,第i个元素的下标为i-1*/L->last++;return<OK>;}intDelList<SeqList*L,ElemType*m>{intw;cout<<"请输出要删除的元素位置:"<<endl;cin>>w;intk;if<<w<1>||<w>L->last+1>>{cout<<"删除位置不合法!"<<endl;;return<ERROR>;}*m=L->elem[w-1];/*将删除的元素存放到e所指向的变量中*/for<k=w;k<=L->last;k++>L->elem[k-1]=L->e