标题:[求助]Josephus问题
只看楼主
我是一只小菜鸟
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-12-19
 问题点数:0 回复次数:5 
[求助]Josephus问题
3, Josephus问题
1世纪著名历史学家Josephus,在犹太人和古罗马人战争期间,和其他40名犹太反抗者陷入罗马人陷阱。他们决定宁死不做俘虏,于是围成1个圆圈(位置p[1]-p[41]),由某一人(位置p[1])开始顺时针杀死其下一人(位置p[2]),直到没人活下(p[41]将杀死p[1])。但Josephus迅速计算得出了一个可以不死位置。试计算其所在的位置。
(选做)推广给出当有n名反抗者时可以存活的位置的一个递归式。
搜索更多相关主题的帖子: Josephus 
2006-12-19 22:00
fengwei
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2006-12-19
得分:0 

#include <stdio.h>
#define N 41
int flag=0;
int fn(int a[],int n);

void main()
{

int a[N];
int i;
for(i=0;i<N;i++) a[i]=i+1;
printf("最后一个人是%d\n",fn(a,N));
}

int fn(int a[],int n)
{ int tem;
int i,j;
if (n==1) return a[0];
else
{
if (flag)
{
tem=a[n-1];
for (i=1;i<n;i++)
a[n-i]=a[n-i-1];
a[0]=tem;
}
for(i=1;i<n;i+=2)
for(j=i;j<n;j++)
a[j]=a[j+1];
flag=n%2;
return fn(a,(n+1)/2);

}

}

2006-12-20 13:53
我是一只小菜鸟
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-12-19
得分:0 
谢了啊
2006-12-20 20:44
hujian100
Rank: 1
等 级:新手上路
帖 子:69
专家分:0
注 册:2006-9-14
得分:0 
可否解释你的算法??

2006-12-20 23:25
fengwei
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2006-12-19
得分:0 
看另外一个帖子。。这个里面的有点问题
2006-12-20 23:27
fengwei
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2006-12-19
得分:0 
2006-12-20 23:31



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




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

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