



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
C语言实现 约瑟夫环问题-单向循环链表实现 问题描述: 有n个人围成一圈进行报数游戏,从第一个人开始报到m的人出圈,接下来有从下一个人开始,。一次这样往复,直到最后一个人也出圈,求他们的出圈顺序?(例如8个人,凡报3的人出圈,则他们出圈顺序是 3 ,6, 1, ,5 , 2 , 8, 4 ,7) #include#includetypedef struct nodeint value;struct node *next;NODE;/*建立循环链表(尾插法建立)*/NODE *createlink(int number)NODE *head=NULL,*p=NULL,*q=NULL;int i=1;head=(struct node*)malloc(sizeof(struct node); /*建立第一个节点*/ head-value=i;p=head;for(i=2;inext=q; p=q; p-value=i; p-next=head;return head; /*建立约瑟夫环*/ void jose(NODE *p,int number,int n)int i,j,g=0;NODE *q=NULL;for(i=1;i=number;i+) for(j=1;jnext; q=p-next; /*q用来记录要删除的节点*/ p-next=q-next; /*删去q节点*/p=p-next;printf(第%3d个出圈号是:%3dn,i,q-value); free(q);printf(n);/p-next=NULL; 此表达式不能出现在此处,最后一个节点删除后就不存在了 /*主函数*/ int main( )int number=0;int n=0;printf(请输入总人数number和出拳编号n:n); scanf(%d,&number); scanf(%d,&n); NODE *head=NULL;head=createlink(number)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 个人租车合同范本
- 承接高空吊装合同范本
- 古代租房合同范本
- 司机劳务合同范本简单
- 股权质押登记合同范本
- 加工店铺转让合同范本
- 装修居间合同范本
- 监控施工改造合同范本
- 政府采购业务合同范本
- 标准的工程合同范本
- 高等代数(上)期末复习题
- 应急资源调查表
- 北师大版八年级上册数学第二章实数单元测试卷(含答案)
- 同步控制器说明书
- 05G514-3 12m实腹式钢吊车梁(中级工作制 A4 A5 Q345钢)
- GB/T 902.3-2008储能焊用焊接螺柱
- 土石方填方合同(6篇)
- 汽轮机原理-凝汽器课件
- 典范英语7-2中英文对照翻译Noisy Neighbours
- 海思芯片HTOL老化测试技术规范
- 最新版个人征信报告(可编辑+带水印)
评论
0/150
提交评论