118
社区成员




有n人围成一圈,顺序排号。从第1个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来的第几号的那位。
####相关知识(略)
####编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。
输入
初始人数n
输出
最后一人的初始编号
####测试说明
样例输入:
3
样例输出:
2
代码:
#include<stdio.h>
int main(void)
{
int n,i,k,m,a[100];
int *p;
p=&a;
scanf("%d",&n);
for(i=0;i<n;i++)
{
a[i]=i+1;
}
i=0;
k=0;
m=0;
while(m<n-1)
{
if(a[i]!=0)
{
k++;
}
if(k==3)
{
a[i]=0;
k=0;m++;
}
i++;
if(i==n)
i=0;
}
while(!(*p))
{
p++;
}
printf("%d",*p);
return 0;
}