




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验报告一题目:约瑟夫环路 班级:信息管理与信息系统姓名:王志钢 学号:20081121614指导教师:孟繁军 完成日期:2010.6.25一需求分析1.约瑟夫环(Joseph)问题的一种描述是:编号为1,2,n的n个人按顺时针方向围坐一圈,每人持有一个密码(正整数)。一开始任选一个正整数作为报数上限值m,从第一个人开始按顺时针方向自1开始顺序报数,报到m时停止报数。报m的人出列,将他的密码作为新的m值,从他在顺时针方向上的下一个人开始重新从1报数,如此下去,直至所有人全部出列为止。2.演示程序以用户和计算机的对话方式执行,即在计算机终端上显示“提示信息”之后,有用户在键盘上输入演示程序中规定的运算命令,相应的输入数据和运算结果显示在其后。3.程序执行的命令包括:1)输入初始密码和人数 2)输入所有人的密码 3)显示输入的所有人的编号及相应的密码4)输出出列密码及编号 5)结束4.测试数据(1)m=20, n=7, 7个人的密码依次为3,1,7,2,4,8,4(2)m=20,n=1(3)m=20,n=0前面一组为常规数据,后面两组为边缘数据二、概要设计为实现上述功能,应以有序单向循环链表表示约瑟夫环。为此,需要有一个抽象数据类型。该抽象数据类型的定义为:ADT LinkList数据对象:D= ai | ai termset,i=1,2,n,n=0,termset中每个元素包含编号,密码,和一个指向下一节点的指针数据关系:R1= | ai-1, ai D , i=2,n基本操作:LinkList EvaluList(int n);/对单向循环链表进行尾插入赋值int size(LinkList L);/求链表的节点个数Status ScanList(LinkList L);/遍历单向循环链表Status Joseph(LinkList &L,int m);/约瑟夫环的实现此抽象数据类型中的一些常量如下:#define TRUE 1#define FALSE 0#define OK 1typedef int Status;typedef double ElemType;单向循环链表中节点的定义如下所示:typedef struct LNodeint number;int data;struct LNode *next;LNode, *LinkList;三、详细设计编号为1,2,n的n个人按顺时针方向围坐一圈,每人持有一个密码(正整数)。一开始任选一个正整数作为报数上限值m,从第一个人开始按顺时针方向自1开始顺序报数,报到m时停止报数。报m的人出列,将他的密码作为新的m值,从他在顺时针方向上的下一个人开始重新从1报数,如此下去,直至所有人全部出列为止。试设计一个程序求出出列顺序。四运行环境Dev -C+五调试分析 1.当执行输入人数时,输入0程序出现了意想不到的错误,所以再重新设计时加入了对空节点的处理2.在链表节点的设计上,最初是仅包含密码和指针,但是后来考虑到链表节点删除时会带来一系列的编号变化,编号难以确定,所以节点设计上又加了一个编号3.在单向链表的赋值操作时,原本是以一个不变的L作为头结点,但是这种赋值方法带来了诸多变量设计的问题,所以将L为节点,赋值完成后,再让L指向头结点六、用户使用说明:题目:约瑟夫环路本程序将利用单向循环链表存储结构模拟此过程,按照出列的顺序印出各人的编号。测试数据输入m的初值为20,n的初值7;依次输入密码:3,1,7,2,4,8,4输出:当前密码为 ,出列编号为 七、源代码#includeusing namespace std;#define TRUE 1#define FALSE 0#define OK 1typedef int Status;typedef double ElemType;/-/定义单向循环链表typedef struct LNodeint number;int data;struct LNode *next;LNode, *LinkList;/-LinkList EvaluList(int n);/对单向循环链表进行尾插入赋值int size(LinkList L);/求链表的节点个数Status ScanList(LinkList L);/遍历单向循环链表Status Joseph(LinkList &L,int m);/约瑟夫环的实现 /-void main()int m,n;cout请输入初始密码(正整数)和人数mn;coutendl请输入n个人的密码endlendl;LinkList L=EvaluList(n);coutn个人的密码为endl;ScanList(L);coutn个人的出列顺序为endl;Joseph(L,m);/-对单向循环链表进行尾插入赋值-LinkList EvaluList(int n)if(n=0)return NULL;int key;coutkey;LinkList L=new LNode;L-data=key;L-number=1;L-next=L;for(int i=2;i=n;i+)LinkList p=new LNode;int key;cout输入第ikey;p-data=key;p-number=i;p-next=L-next;L-next=p;L=L-next;coutnext;return L;/-求链表的节点个数-int size(LinkList L)if(L=NULL)return 0;int i=1;LinkList p=L-next;while(p!=L)i+;p=p-next;return i;/-遍历单向循环链表-Status ScanList(LinkList L)LinkList p=L;if(p=NULL)cout人数为空endl;return FALSE;cout第1个人的密码 ;coutdatanext;while(p!=L)cout第number个人的密码 ;coutdatanext;coutendl;return TRUE;/-约瑟夫环的实现-Status Joseph(LinkList &L,int m)if(L=NULL)cout人数为空,出列结束next!=L)p=p-next
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 内科学高血压试题(附答案)
- 足疗按摩技巧与穴位解析试题及答案
- 2025年基因治疗药物临床研究新技术突破与市场前景分析报告
- 推拿治疗学试题及答案详解【真题汇编】
- 2025年新能源汽车废旧电池回收利用产业链风险控制报告
- 2025年数字艺术市场创作与交易市场潜力与发展趋势分析报告
- 2025至2030年中国粽子行业发展监测及投资战略规划研究报告
- 国际合作协议示范条款
- 园林绿化作业人员试题完整版附答案详解
- 2025版潍坊市房地产行业劳动合同范本
- GB 46031-2025可燃粉尘工艺系统防爆技术规范
- 近十年中职试卷及答案
- 【无线射频电路】-微波笔记·糖葫芦低通滤波器的设计
- 商业装修手册
- 医院信息互联互通化成熟度测评
- 股票k线图入门图解
- GB/T 15812.1-2005非血管内导管第1部分:一般性能试验方法
- 无轨运输安全操作规程
- 专升本英语统考试翻译技巧课堂教学课件2
- 视频拍摄入门(上)课件
- 除颤仪的使用及护理
评论
0/150
提交评论