下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上实验名称:约瑟夫环问题 实验类型:综合性实验 班级: 学号:姓名:李晓彬实验日期:2012.04.282.问题描述设有编号为1,2,n的n(n0)个人围成一个圈,每个人持有一个密码m。从第一个人开始报数,报到m时停止报数,报m的人出圈,再从他的下一个人起重新报数,报到m时停止报数,报m的出圈,如此下去,直到所有人全部出圈为止。当任意给定n和m后,设计算法求n个人出圈的次序。3.数据结构设计设计实现约瑟夫环问题的存储结构。由于约瑟夫环问题本身具有循环性质,考虑采用循环链表,为了统一对表中任意结点的操作,循环链表不带头结点。将循环链表的结点定义为如下结构类型:struct
2、 Node int data; Node *next;4.算法设计一个主函数,两个功能函数。Step1:定义数据结构类型Step2:建立功能函数NODE *createlink(int n)完成建立循环链表的功能。 for(i=2;i<=n;i+) q=(struct node*)malloc(sizeof(struct node); if(q=0) return 0; p->next=q; p=q; p->data=i; Step3: 功能函数void jose(NODE *p,int n,int m)完成报数m出圈的功能。for(i=1;i<=n;i+) for(j
3、=1;j<m;j+)p=p->next; q=p->next; p->next=q->next; if(k%6=0) k+;printf("n"); else k+; printf("%3d:%3dout ",i,q->data-1); free(q); Step4: 主函数完成本实验的主体功能即得到出圈次序,并打印。 NODE *head=NULL; head=createlink(n); jose(head,n,m); 5. 抽象数据类型的设计 NODE *head,*p,*qint m,n,MAX_NODE_NU
4、M,I,k6.界面设计 欢迎使用约瑟夫环问题程序1 请输入人数n(最多1000个);2 初始密码m:3 结果7.运行、测试与分析(1)运行程序,显示菜单 : (2)输入n:(3)输入m:(4)结果:8.实验收获及思考对单链表的知识掌握的更加透彻,而且自己一步一步编写程序有一点点的成就感。编写程序的过程中界面的友好程度是一个很重要的指标,下次要努力编写一个界面友好的程序。附录源代码:#include<stdio.h>#include<stdlib.h>typedef struct nodeint data;struct node *next;NODE; /*定义
5、节点*/ NODE *createlink(int n)NODE *head=NULL,*p=NULL,*q=NULL;int i=1; head=p=(struct node*)malloc(sizeof(struct node);p->data=i;for(i=2;i<=n;i+) q=(struct node*)malloc(sizeof(struct node); if(q=0) return 0; /分配失败 p->next=q; p=q;/创建新的节点 p->data=i; / 为 每个人分配序号 p->next=head;/循环 return hea
6、d;/返回要用的首地址 /*创建循环链表*/ void jose(NODE *p,int n,int m)int i,j,k=0;NODE *q=NULL;for(i=1;i<=n;i+) for(j=1;j<m;j+)p=p->next; /*访问到每轮的第m-1个*/ q=p->next; /*q是第m个*/ p->next=q->next; /*p直接指向第m+1个*/ if(k%6=0) k+;printf("n"); else k+; /*让出圈的数字一行显示六个*/printf("%3d:%3dout ",
7、i,q->data-1); /*输出出圈的次序和要出圈的值*/ free(q);/*释放节点*/ printf("n");p->next=NULL; /一直到下一个为空即要出圈已经出的了 /*约瑟夫环*/ int main( )int m,n,MAX_NODE_NUM=1000;while (1) printf("欢迎使用约瑟夫环问题程序n") ; printf("1.请输入人数n(最多%d个): ", MAX_NODE_NUM); scanf("%d", &n); printf("2.初始密码m: "); scanf("%d", &m); printf("3.结果"); if (n > MAX_NODE_NUM) printf("人数太多,请重新输入!n"); continue; else brea
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 111.2025年纳米材料核磁共振波谱元素分析表征技术考试试卷
- 2025年成都东部新区第四中学校教师招聘备考题库及1套参考答案详解
- 中国人民人寿保险股份有限公司重庆市分公司2026年度校园招聘备考题库及1套参考答案详解
- 2025年定西市通渭县公开招聘乡村医生7人备考题库及1套完整答案详解
- 2025年北京老年医院应届毕业生公开招聘43人备考题库附答案详解
- 2025年柳州市航鹰中学招聘语文教师招聘备考题库及1套完整答案详解
- 2025年人民交通出版社招聘13人备考题库及完整答案详解一套
- 2025年喀喇沁旗公开招聘基层医疗卫生机构专业技术人员备考题库参考答案详解
- 元阳县2026年教育体育系统事业单位校园公开招聘备考题库及一套答案详解
- 乐山职业技术学院2025年下半年公开考核招聘工作人员备考题库及一套完整答案详解
- 济南市2025-2030年中小学及幼儿园布局规划方案公示细节
- (2025年标准)铁路实习协议书
- 重庆市涪陵榨菜集团股份有限公司营运能力分析
- 与4s店二手车合作合同协议
- 《中华民族共同体概论》考试复习题库(含答案)
- 国家开放大学《公共政策概论》形考任务1-4答案
- 学堂在线 雨课堂 学堂云 西方哲学精神探源 期末考试答案
- 2025年楚雄州金江能源集团有限公司招聘考试试题【答案】
- 道路应急抢修方案
- 顶管穿越公路安全评估(二篇)
- 人体工程学-第五章-人体工程学与室外环境设施设计
评论
0/150
提交评论