- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构实验范例
附录 实验报告参考规范
《数据结构》实验报告
院系__物光__ 专业 ________网工________
姓名__________ 学号_106052010233__ 电话___
____2010______级 ____6______班 _______年____月____日
1.实验题目
编制一个演示单链表的建立、打印、查找、插入、删除等操作的程序。
2.需求分析
(以无歧义的陈述说明程序设计的任务,强调的是程序要做什么?并明确规定:
(1) 输入的形式和输入值的范围;
(2) 输出的形式;
(3) 程序所能达到的功能;
(4) 测试数据:包括正确的输入及其输出结果和含有错误的输入及其输出结果。)
例如:
要求用TC编写一个演示程序,首先建立一个带头结点的整型单链表,然后根据用户选择,能够在单链表的任意位置插入、删除结点,以及确定某一元素在单链表中的位置。
建立单链表功能
输入的形式和输入值的范围:输入若干正整数,用空格分隔,用-1表示结束。
输出的形式:按输入顺序显示所建立单链表中各结点的值。
测试数据:输入11 12 13 14 15 16 -1后,显示建立的单链表为:11 12 13 14 15 16
插入功能
输入的形式和输入值的范围:输入一个表示插入位置的正整数和一个表示元素值的正整数,两个正整数用空格分隔。插入位置的合法取值范围是1到当前表长加1。
输出的形式:如果输入参数合法,则按顺序显示插入后单链表中各结点的值,否则显示参数错误信息。
测试数据:在前面所建单链表的基础上,做下面测试:
输入6 100后,显示插入后的单链表为:11 12 13 14 15 100 16
输入0 200后,显示参数错误信息。
输入9 200后,显示参数错误信息。
输入8 200后, 显示插入后的单链表为:11 12 13 14 15 100 16 200
删除功能
输入的形式和输入值的范围:输入一个表示删除位置的正整数,删除位置的合法取值范围是1到当前表长。
输出的形式:如果输入参数合法,则按顺序显示删除后单链表中各结点的值,否则显示参数错误信息。
测试数据:在前面插入后单链表的基础上,做下面测试:
输入9后,显示参数错误信息。
输入8后,显示删除后的单链表为:11 12 13 14 15 100 16
查找功能
输入的形式和输入值的范围:输入一个要查找的元素值,元素值的合法取值范围是正整数。
输出的形式:如果存在要查找的元素,则显示要查找元素的序号位置,否则显示参数错误信息。
测试数据:在前面插入、删除后单链表的基础上,做下面测试:
输入200后,显示参数错误信息。
输入100后,显示100的序号位置为6
3.概要设计
(说明本程序中用到的所有抽象数据类型的定义、主程序的流程以及各程序模块之间的层次(调用)关系。)
例如:
为了实现上述程序功能,需要定义一个简化的线性表抽象数据类型:
ADT LinearList {
数据对象:D={ai|ai∈IntegerSet,i=0,1,2,…,n,n≥0}
结构关系:R={ai,ai+1|ai,ai+1 ∈D}
基本操作:
InitLinkList(L)
操作前提:L是一个未初始化的线性表
操作结果:将L初始化为一个空的线性表
CrtLinkList(L)
操作前提:L是一个已初始化的空表
操作结果:建立一个非空的线性表L
InsLinkList(L,pos,e)
操作前提:线性表L已存在
操作结果:将元素e插入到线性表L的pos位置
DelLinkList(L,pos,e)
操作前提:线性表L已存在
操作结果:将线性表L中pos位置的元素删除,
删除的元素值通过e返回
LocLinkList(L,e)
操作前提:线性表L已存在
操作结果:在线性表L中查找元素e,
若存在,返回元素在表中的序号位置;
若不存在,返回-1
}
本程序包含6个函数:
主函数main()
初始化单链表函数InitLinkList()
显示单链表内容函数dispLinkList()
插入元素函数InsLinkList()
删除元素函数DelLinkList()
查找元素函数LocLinkList()
各函数间调用关系如下:
mainInitLink
您可能关注的文档
- 数学必修一1.1.3-2集合运算课件.ppt
- 数学模型的建立过程.doc
- 数字逻辑电路 2逻辑函数及其简化.ppt
- 数学:1.1.3《集合的基本运算(全集与补集)》课件(新人教A版必修1).ppt
- 数学:1.1.3《集合的基本运算(第2课时)》课件(新人教A版必修1).ppt
- 数学:1.1.3 集合的基本运算 第1课时课件(新人教A版必修1).ppt
- 数学:1.1.3《集合的基本运算(二)》课件(新人教A版必修1).ppt
- 数学:1.1.3《集合的基本运算》课件(新人教A版必修1).ppt
- 数学:1.1.3《集合的基本运算》测试(新人教A版必修1).doc
- 数学:1.2.1《常数函数与幂函数的导数》.ppt
- 第十一章 电流和电路专题特训二 实物图与电路图的互画 教学设计 2024-2025学年鲁科版物理九年级上册.docx
- 人教版七年级上册信息技术6.3加工音频素材 教学设计.docx
- 5.1自然地理环境的整体性 说课教案 (1).docx
- 4.1 夯实法治基础 教学设计-2023-2024学年统编版九年级道德与法治上册.docx
- 3.1 光的色彩 颜色 电子教案 2023-2024学年苏科版为了八年级上学期.docx
- 小学体育与健康 四年级下册健康教育 教案.docx
- 2024-2025学年初中数学九年级下册北京课改版(2024)教学设计合集.docx
- 2024-2025学年初中科学七年级下册浙教版(2024)教学设计合集.docx
- 2024-2025学年小学信息技术(信息科技)六年级下册浙摄影版(2013)教学设计合集.docx
- 2024-2025学年小学美术二年级下册人美版(常锐伦、欧京海)教学设计合集.docx
文档评论(0)