已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
计算机科学与工程学院计算机科学与工程学院算法与数据结构试验报告一专业班级10级计算机工程02试验地点计算机大楼计工教研室学生学号1005080222指导教师蔡琼学生姓名肖宇博试验时间2012-2-29试验项目算法与数据结构试验类别基础性() 设计性() 综合性() 其它( )试验目的及要求(1) 掌握用VC+上机调试线性表的基本方法; (2)掌握顺序表的存储结构以及基本运算的实现。成 绩 评 定 表类 别评 分 标 准分值得分合 计上机表现积极出勤、遵守纪律主动完成设计任务30分程序与报告程序代码规范、功能正确报告详实完整、体现收获70分备注: 评阅教师: 日 期: 年 月 日试 验 内 容 一、实验目的和要求1、实验目的:(1)掌握用VC+上机调试线性表的基本方法; (2)掌握顺序表的存储结构以及基本运算的实现。2、实验内容约瑟夫环问题:设编号为1,2,3,n的n(n0)个人按顺时针方向围坐一圈,m为任意一个正整数。从第一个人开始顺时针方向自1起顺序报数,报到m时停止并且报m的人出列,再从他的下一个人开始重新从1报数,报到m时停止并且报m的人出列。如此下去,直到所有人全部出列为止。要求设计一个程序模拟此过程,对任意给定的m和n,求出出列编号序列。3、实验要求:用顺序表实现。2、 设计分析根据实验要求,采用顺序表来完成本次实验。实验中定义了两个顺序表,一个用来存储n个人的序号,另一个用来存储n个人的出队顺序及序号。程序中充分考虑了如果出队的元素大于队列的元素个数时应该有的情况,如果出现这样的错误就提示!否则继续出队!3、 源程序代码#include#include#define MAXSIZE 10 / 宏替换最大值typedef structint dataMAXSIZE;int length;Sqlist;void CreatList(Sqlist *&L,int a,int n) /创建顺序表L=(Sqlist *)malloc(sizeof(Sqlist);for(int i=0;idatai=ai;L-length=n;void InitList(Sqlist *&L) /初始化顺序表L=(Sqlist *)malloc(sizeof(Sqlist);L-length=0;void DestoryList(Sqlist *&L) /释放顺序表空间free(L);void josephus(Sqlist *&L) /约瑟夫环的核心代码int t=0;int m=0;printf(请输入数到几个人出来);printf(n);scanf(%d,&m);if(mL-length)printf(没有这么多人呀!(_);elseprintf(出列顺序为:);for(int q=L-length;q=1;q-)t=(t+m-1)%q;printf(n);printf(t%dt,L-datat);for(int j=t+1;jdataj-1=L-dataj;printf(n);void main()Sqlist *s;InitList(s);int aMAXSIZE;int n=0;printf(请键入要输入几个数);printf(n);scanf(%d,&n);for(int i=0;in;i+)ai=i+1;CreatList(s,a,n);josephus(s);DestoryList(s);printf(n);四、测试用例(尽量覆盖所有分支)1.当输入1,2,3,4。n的这些数字范围以内的话,可以得到正确的结果如图:2.当输入的n比较大的时候的情况如图:3.当输入序列少,出对数大时:4.当输入要出列的元素大于队列里的元素,这将会提示错误如图:5.当你的输入出队的序列数有误时将会提示错误6.当你的要输入的数大于定义的最大值时提示错误如图:7.当你的要输入的数小于定义的最大值时提示错误如图:五、实验总结 先后学习了C/C+,对编程语言基本上有一些了解,但在数据结构试验程序设计过程中还是学到了很多。经过两天的设计,在不断翻阅以前资料的情况下,有针对性的复习了C/C+中指针、循环的相关理论知识和vc6.0的基础知识和应用技巧,最后比较成功的完成了本次的设计。本次设计是运用已学的线性表中顺序表的相关内容,由于以前的指针方面知识没有学好,刚开始时有些措手不及,尤其是运用指针申请动态内存,遇到了不小的麻烦,程序检查时没有错误,但运行不了,经过仔细的思考,终于发现了问题所在,特别高兴。程序运行后,开始考虑各种BUG,比如输入的数大于数组定义的最大值的时候抑或是数组的数小于应该输入的最小值(比如0),比如输入的要出列的元素大于队列中已有的元素抑或是小于数组中应该出现的元素,比如一些错误输入等等之内的BUG 都考虑之后的问题。然后思考与反思后,发现程序还是有美中不足的地方,算法的核心存在一些不足,比如依次从后往前挪动一个元素的时候存在一些效率上的问题,当元素较多时,效率不高!考虑到可以采用标记法,把出队元素标记为0,以后的出队的时候跳过0,而不是进行挪动,这样程序的效率就大大提高了!本次实验运用的是C语言,大一时就学过了,在今后的试验中应该多尝试其他的语言来写程
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 智慧研究:知识产权驱动-本科研究中的知识产权保护
- 2026 减脂期答疑解惑课件
- 2025年小学英语毕业考试模拟试卷:语法专项突破句子结构分析
- 肿瘤内科健康教育处方
- 医学26年:高颅压性头痛诊疗 查房课件
- 26年NCCN国内适配指引
- 2026 减脂期个性化课件
- 食道癌患者的营养支持护理
- 镇痛护理案例分析
- 高血压患者的压力管理技巧
- 上海会展展览行业劳动合同模板
- 循环流化床锅炉启动调试导则
- 下基层调研工作制度
- JJG 621-2012 液压千斤顶行业标准
- T-GDWCA 0035-2018 HDMI 连接线标准规范
- 小升初语文文言文阅读历年真题50题(含答案解析)
- 头晕教学讲解课件
- 电气化铁路有关人员电气安全规则2023年新版
- GB/T 23853-2022卤水碳酸锂
- GB/T 16823.3-2010紧固件扭矩-夹紧力试验
- 2023年深圳市南山区事业单位招聘笔试题库及答案解析
评论
0/150
提交评论