标题:求解Josephus问题的函数
只看楼主
无语随风
Rank: 1
等 级:新手上路
帖 子:22
专家分:7
注 册:2009-7-13
结帖率:100%
 问题点数:0 回复次数:3 
求解Josephus问题的函数
   void Josephus(int A[],int n,s,m){

   int i,j,k,tmp;

    if(m==0){  

 printf("m=0是无效的参数!\\n");  

return;  

}  

for(i=0;i<n;i++)A[i]=i+1;          /*初始化,执行n次*/

i=s-1;  /*报名起始位置*/

 for(k=n;k>1;i--){  /*逐个出局,执行n-1次*/

  if(i==k)i=0;  

 i=(i+m-1)%k;/*寻找出局位置*/
 
if(i!=k-1){


 tmp=A[i];  /*出局者交换到第k-1位置*/

  for(j=i;j<k-1;j++)A[j]=A[j+1];

 A[k-1]=tmp;
 
}

  }
 for(k=0;k<n/2;k++){  /*全部逆置,得到出局序列*/

  tmp=A[k];A[k]=A[n-k+1];A[n-k+1]=tmp;

}

}

各位前辈,我看不懂这段代码,忘指点,尤其是第九行的for(k=n;k>1;i--){  和十一行的 i=(i+m-1)%k,还有这段代码的思想,谢谢各位大侠。

我还没积分,有了一定追加给各位。
搜索更多相关主题的帖子: 求解 函数 Josephus 
2009-10-31 19:30
tdy1006
Rank: 4
等 级:业余侠客
帖 子:173
专家分:240
注 册:2009-5-13
得分:0 
i--:每出局一个,坐标就往前移一个,再数m个才是下一个出局的,
i=(i+m-1)%k:打个比方,有10个人数到12就越界了,取余就可以回到2了,


这个程序先把出局的从数组最后依次往前放,
最后再倒过来
2009-10-31 22:00
bingsai121
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2009-11-8
得分:0 
这个比较好懂,你看这个吧,这也是josephus:
#include <stdio.h>
#include <stdlib.h>

#define N 13
#define M 3
typedef struct node *link;
struct node{
    int item;
    link next;
};
link NODE(int item, link next)
{
    link t = malloc(sizeof *t);
    t->item = item;
    t->next = next;
    return t;
}
int main()
{
    int i;
    link t = NODE(1,NULL);
    t->next = t;
    for (i=2; i<=N; i++)
        t = t->next = NODE(i, t->next);
    while (t != t->next) {
    for (i=1; i<M; i++)
        t = t->next;
    t->next = t->next->next;
    }
    printf("%d\n",t->item);
    return 0;
}

2009-11-08 23:01
d7d7
Rank: 4
等 级:业余侠客
帖 子:91
专家分:210
注 册:2008-9-29
得分:0 
这个程序意思是有n个人,报数当报到m次就出局,但把它放在本局数组最后一个数那里。
i=(i+m-1)%k;/*寻找出局位置*/ 这句写得好
2009-11-08 23:23



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-290605-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.523639 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved