约瑟夫环问题

问题描述:有n个人排成一圈,循环报数,毎到数字k,那人自动退出,下个人继续从1开始报数,如此循环,直至剩下最后一个人。问最后那个人的序号是多少?

代码如下:

 1 //约瑟夫环问题,以n为总人数,k(此处为3)为循环退出的序号
 2 #include<stdio.h>
 3 int c[100];
 4 int *p;
 5 int n,k;
 6 int main()
 7 {
 8     p=c;
 9     void Josephus(int *,int,int);
10     printf("请输入总人数n,要退出的序号k:");
11     scanf("%d%d",&n,&k);
12     Josephus(p,n,k);
13     return 0;
14 }
15 
16 void Josephus(int *p,int n,int k)
17 {
18     int i,j,m;
19     for(i=0;i<n;i++) *(p+i)=i+1;  //将0号单元编成1号位
20     i=0;
21     j=0;
22     m=0;
23     
24     while(m<n-1)    //m从零开始,这样总共退留个人,想留x个人,条件表达式为m<n-x
25     {
26         if(*(p+i)!=0) j++;
27         if(j==k)
28         {
29             *(p+i)=0;
30             j=0;    //把这个位置设0,下一非零位置开始继续j从1计数
31             m++;
32         }
33         i++;
34         if(i==n) i=0;
35     }
36     
37     for(i=0;i<n;i++) 
38     {
39         if(*p!=0)
40         {
41             printf("最后剩下的人的编号是:%d\n",*p);
42             //break;
43         }
44         p++;
45     }
46 }

运行结果:

 

posted @ 2020-03-16 16:33  kakusan  阅读(154)  评论(0编辑  收藏  举报