约瑟夫循环实验报告_第1页
约瑟夫循环实验报告_第2页
约瑟夫循环实验报告_第3页
约瑟夫循环实验报告_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论