CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
IBM Rational 系统开发最佳实践工具包 WebSphere MQ 最佳实践 TOP 15
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  C/C++ >  C语言

用单向循环链表解决约瑟夫环问题

楼主yanting04(夕阳岛外)2006-03-16 21:51:33 在 C/C++ / C语言 提问

设有n个人围坐一圈,现以某个人开始报数,数到m的人出列,接着从出列的下一个人开始重新报数,数到m的人又出列,如此下去,直到所有人都出列为止.按出列顺序输出.    
  问题点数:50、回复次数:2Top

1 楼llf_hust()回复于 2006-03-16 22:00:26 得分 50

#include   <stdio.h>  
  #include   "stdlib.h"  
  struct   ele{  
  int   no;  
  struct   ele   *link;  
  }  
  main()  
  {  
   
  struct   ele   *h,*u,*p;  
                  int   n,m,i;  
  printf("Please   input   n&m:\n");  
  scanf("%d%d",&n,&m);/*输入n和m*/  
  h=u=(struct   ele   *)malloc(sizeof(struct   ele));/*形成首表元*/  
  h->no=1;  
  for(i=2;i<=n;i++)/*形成其余的n-1个表元*/  
  {  
  u->link=(struct   ele   *)malloc(sizeof(struct   ele));  
  u=u->link;  
  u->no=i;/*第i个表元置编号i*/  
  }  
  u->link=h;/*末表元后继首表元,形成环*/  
  puts("\nThe   numbers   of   who   will   quit   the   cycle   in   turn   are:");  
  while(n)  
  {  
  for(i=1;i<m;i++)/*掠过m-1个表元*/  
  u=u->link;  
  p=u->link;/*p指向第m个表元*/  
  u->link=p->link;/*第m个表元从环中脱钩*/  
  printf("%4d",p->no);  
  free(p);/*释放第m个表元占用的空间*/  
  n--;  
  }  
  printf("\n\n   Press   any   key   to   quit...\n");  
  getchar();  
  }  
  Top

2 楼yanting04(夕阳岛外)回复于 2006-03-17 18:39:09 得分 0

非常感谢啊!Top

相关问题

  • 约瑟夫环的调试
  • 用循环链表来求解约瑟夫问题(欢迎大家给提意见)
  • 100分,约瑟夫环,谢谢指点!
  • 约瑟夫环问题,请指教!
  • 约瑟夫环有无数学解法?
  • 单向链表局部循环判定?
  • 谁能教我做一下约瑟夫环??
  • 400分求vb的约瑟夫环的写法,在线等!!~~~~~~~~~~~~~~~~~
  • 400分求vb的约瑟夫环的写法,在线等!!~~~~~~~~~~~~~~~~~
  • 求一C写的约瑟夫环问题的程序!

关键词

  • 环
  • struct ele
  • 表元
  • link
  • 出列
  • printf
  • 人

得分解答快速导航

  • 帖主:yanting04
  • llf_hust

相关链接

  • C/C++ Blog
  • C/C++类图书
  • C/C++类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo