- 1、本文档共25页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
实验报告
学院:信息工程学院专业:计算机
信息工程学院计算机实验中心制
《数据结构》实验报告
姓名张文楚学号409109070515日期2011.4.17-8节
实验室计算机基础实验室指导教师张有华设备编
号
实验题实验二线性表的顺序存储结构
目
一实验内容
1.进一步熟悉C语言的上机环境,掌握C语言的基本结构。
2.会定义线性表的顺序存储结构。
3.熟悉对顺序表的一些基本操作(建表、插入、删除等)和具体的
函数定义。
二实验目的
掌握顺序存储结构的特点,了解、掌握并实现顺序表的常用的基
本算法。
三需求设计
线性表抽象数据类型的描述及实现
ADTList{
DaaElemSeti12nn,,,,{|,,,,,0}数据对象:ii
RaaaaDi2n,,,,,{,|,,,,}数据关系:i1ii1i,,
基本操作:构造一个空的线性表LInitList();
销毁线性表LDestroyList();
将L重置为空表ClearList();
判断L是否为空ListEmpty();
求表长
ListLength();
查找元素
LocateElem();
求前驱PriorElem();
求后继NextElem();
插入元素
ListInsert();
删除元素
ListDelete();
元素调用visit()函数ListTraverse(L,visit())
}ADTList;
程序具体实现要求:
1.创建一个线性表
2.能输出所有数据元素
3.能求线性表长度
4.能插入删除元素
5.能查找元素
6.能求元素的前驱和后继
7.用户操作界面如下:
**********************************
*1.构造线性表
*2.插入元素
*3.删除元素
*4.查找元素
*5.显示表长
*6.求后继
*7.求前驱
*8.输出所有元素
*0.结束程序运行
***********************************
请输入您的选择(0,1,...,8):
四详细设计
步骤1:给出线性表的抽象数据类型的定义。
ADTList{
DaaElemSeti12nn,,,,{|,,,,,0}数据对象:ii
RaaaaDi2n,,,,,{,|,,,,}数据关系:i1ii1i,,
基本操作:
InitList(L);
操作结果:构造一个空的线性表L。
DestroyList(L)
初始条件:线性表L已存在。
操作结果:销毁线性表L。
ClearList(L)
初始条件:线性表L已存在。
操作结果:将L重置为空表。
ListEmpty(L)
初始条件:线性表L已存在。
操作结果:若L为空表,则返回TRUE,否则返回FALSE。
ListLength(L)
初始条件:线性表L已存在。
操作结果:返回L中数据元素个数。
GetElem(L,i,e)
初始条件:线性表L已存在,1?i?ListLength(L)。
操作结果:用e返回L中第i数据个元素的值。
LocateElem(L,e,compare())
初始条件:线性表L已存在,compare()是数据元素
判定函数。
操作结果:返回L中第1个与e满足关系compare()
的数据元素的位序。若这样的数据元素不
存在,则返回值为0。
PriorElem(L,cur_e,pre_e)
初始条件:线性表L已存在。
操作结果:若cur_e是L的数据元素,且不是第一个,
则用pre_e返回它的前驱,否则操作失败,
pre_e无定义
NextElem(L,cur_e,next_e)
初始条件:线性表L已存在。
操作结果:若cur_e是L的数据元素,且不是最后一
个,则用next_e返回它的后继,否则操作
失败,next_e无定义。
ListInsert(L,i,e)
初始条件:线性表L已存在,1?i?ListLength(L)+1。
操作结果:在L中第i个位置之前插入新的数据元素
e,L的长度加1。
ListDelete(L,i,e)
初始条件:线性表L已存在且非空,1?i?
ListLength(L)。
操作结果:删除L的第i个数据元素,并用e返回其
值,L的长度减1。
ListTraverse(L,visit())
初始条件:线性表L已存在。
操作结果:依次对L的每个数据元素调用函数
visit()。一旦visit()失败,则操作失败。
}ADTList;
步骤2:用C语言给出线性表的
文档评论(0)