圆桌上围坐着2n个人。其中n个人是好人,另外n个人是坏人。如果从第一个人开始数数,数到第m个人,则立即处死该人;然后从被处死的人之后开始数数,再将数到的第m个人处死……依此方法不断处死围坐在圆桌上的人。试问预先应如何安排这些好人与坏人的座位,能使得在处死n个人之后,圆桌上围坐的剩余的n个人全是好人。
做了一个01数组来进行模拟即可,格式很蛋疼
#include<stdio.h>
int main()
{
int n,m,k=0;
while (scanf("%d%d",&n,&m)!=EOF)
{
int a[66000]={0},c,i=0,t=0;
for (i=0;i<n;++i)
{
c=0;
while (1)
{
if (a[t]==0) {if (++c==m) break;}
if (++t==2*n) t=0;
}
a[t]=1;
}
for (i=0;i<=2*n-1;i++)
{
if (a[i]==0) printf("G"); else printf("B");
if ((i+1)%50==0) printf("\n");
}
printf("\n\n");
}
}