辐射4 7dlc:c语言出圈问题请高人来 解决

来源:百度文库 编辑:查人人中国名人网 时间:2024/05/04 17:02:56
关于出圈问题的疑惑,里面有许多方面不明白,希望高人指点迷津
mafachang () 2004-09-04 04:03:22 在 C/C++ / C语言 提问
题目如下:
34题 设有n个人围坐一圈并按顺时针方向从1到n编号,从第s个人开始进行1到m的报数,报数到第个m人,此人出圈,再从他的下一个人重新开始1到m的报数,如此进行下去直到所有的人都出圈为止。现要求按出圈次序,每10人一组,给出这n个人的顺序表。请考生编制函数Josegh()实现此功能并调用函数WriteDat()把结果p输出到文件OUT.DAT中。
设n=100,c=1,m=10.
(1)将1到n个人的序号存入一维数组p中;
(2)若第i个人报数后出圈,则将p[i]置于数组的倒数第i个位置上,而原来第i+1个至倒数第i个元素依次向前移动一个位置;
(3)重复第(2)步直至圈中只剩下p[1]为止。
部分源程序已给出。
请勿改动主函数main()和输出数据函数writeDat()的内容。 #include <stdio.h>
#define N 100
#define S 1
#define M 10

int p[100],n,s,m;
void WriteDat(void);
void Josegh(void)
{

}

void main()
{
m=M;
n=N;
s=S;
Josegh();
WriteDat();
}
void WriteDat(void)
{
int i;
FILE *fp;
fp=fopen(\ out.dat\ ,\ w\ );
for(i=N-1;i>=0;i--){
printf(\ %4d\ ,p[i]);
fprintf(fp,\ %4d\ ,p[i]);
if(i % 10==0){
printf(\ \\n\ );
fprintf(fp,\ \\n\ );
}
}
fclose(fp);
}
给出的答案:
void Josegh(void)
{
int i,j,s1,w;
s1=s;
for(i=1;i<=n;i++)
p[i-1]=i;
for(i=n;i>=2;i--)
{s1=(s1+m-1)%i;
if(s1==0)
s1=i;
w=p[s1-1];
for(j=s1;j<i;j++)
p[j-1]=p[j];
p[i-1]=w;
}
}
不明白的地方是: "若第i个人报数后出圈,则将p[i]置于数组的倒数第i个位置上,而原来第i+1个至倒数第i个元素依次向前移动一个位置;"我的问题就出来了那倒数第i+1个数以后的就不往前移了吗?还有当m=10,i=100的时候s1=10,w=p[9],p[9]=p[10],p[99]=p[9].继续循环当s1=19,i=99,w=p[18],p[17]=p[18],p[98]=p[18],再当s1=28,i=98,w=p[27],p[27]=p[28],p[97]=p[27],依次类推我的意思是这样理解,如果按我的意思来理解那这不乱套了吗?我想请问高人这到底是怎么样理解的????? 高人啊快来给我讲讲吧!我的QQ 250384861

我的问题就出来了那倒数第i+1个数以后的就不往前移了吗?
这是当时第一个人跳出的时候就将他放在最后一个位置,以就是倒数第一个位置,第二个人跳出,则放在倒数第2个位置,,,,,第i个跳出的人就放在倒数第i个位置

其他的我就不想看了