| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 6099 人关注过本帖
标题:Josephus问题
只看楼主 加入收藏
我是一只小菜鸟
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-12-19
收藏
 问题点数:0 回复次数:17 
Josephus问题
1, Josephus问题
1世纪著名历史学家Josephus,在犹太人和古罗马人战争期间,和其他40名犹太反抗者陷入罗马人陷阱。他们决定宁死不做俘虏,于是围成1个圆圈(位置p[1]-p[41]),由某一人(位置p[1])开始顺时针杀死其下一人(位置p[2]),直到没人活下(p[41]将杀死p[1])。但Josephus迅速计算得出了一个可以不死位置。试计算其所在的位置。
推广给出当有n名反抗者时可以存活的位置的一个递归式
大家帮帮忙啊!!

搜索更多相关主题的帖子: Josephus 
2006-12-19 22:45
fengwei
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2006-12-19
收藏
得分:0 

#include <stdio.h>
#define N 4
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:57
fengwei
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2006-12-19
收藏
得分:0 

上面的有点问题
#include <stdio.h>
#define N 2000
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/2+1]=a[j+1];
flag=n%2;
return fn(a,(n+1)/2);

}

}

2006-12-20 14:23
我是一只小菜鸟
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-12-19
收藏
得分:0 
楼上辛苦了啊,谢谢啊
2006-12-20 20:45
我是一只小菜鸟
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-12-19
收藏
得分:0 

楼上的可不可以解释下啊, 我看不懂啊!
#include <stdio.h>
#define N 2000
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/2+1]=a[j+1];
flag=n%2;
return fn(a,(n+1)/2);

}

}

2006-12-20 21:07
fengwei
Rank: 1
等 级:新手上路
帖 子:57
专家分:0
注 册:2006-12-19
收藏
得分:0 
int fn(int a[],int n)
{ int tem;
int i,j;
if (n==1) return a[0];
else
{
if (flag) //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)/这段是 找到n=2的倍数的位置。用后面的覆盖前

for(j=i;j<n;j++)//的。也就是删除掉n为2的倍数的数据
a[j/2+1]=a[j+1];
flag=n%2;
return fn(a,(n+1)/2);

}

}
2006-12-20 21:48
我是一只小菜鸟
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-12-19
收藏
得分:0 

谢谢了啊,我再研究研究哈

2006-12-20 22:54
xzz88
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-12-21
收藏
得分:0 
恩~~~好象就是2的倍数的位置的问题.
2006-12-21 16:44
hujian100
Rank: 1
等 级:新手上路
帖 子:69
专家分:0
注 册:2006-9-14
收藏
得分:0 

我编的程序,fengwei,你的程序好像有点问题吧 正确答案应该是位置19。

#include <stdio.h>
#define N 41

main()
{
int group[N];
int count=0;
int i,n=41;
for(i=0;i<N;i++)
group[i]=1;
i=0;
while(n>1)
{
while(count!=2)
{
if(i==N)
i=0;
if(group[i]==1)
count++;
i++;
}
count=0;
group[i-1]=0;
n--;
}
for(i=0;i<N;i++)
{
if(group[i]==1)
{
printf("The position is %d\n",i+1);
break;
}
}
return 0;
}


2006-12-21 22:41
crusoe
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2006-12-24
收藏
得分:0 
怪了,楼上的你的程序为啥当N小于41的时候,就出不来结果了?
2006-12-24 21:13
快速回复:Josephus问题
数据加载中...
 
   



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

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