任务描述
题目描述:有n
人围成一圈,顺序排号。从第1
个人开始报数(从1
到3
报数),凡报到3
的人退出圈子,问最后留下的是原来的第几号的那位。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 初始人数n
输出 最后一人的初始编号
测试说明
样例输入: 3
样例输出: 2
#include<stdio.h>
int main(void)
{
/*********Begin*********/
int n,*p = NULL;
int g=0,i,count=0,index;
int a[100];
scanf("%d",&n);
for(int i =1;i<=n;i++)
{
a[i] = i;
}
i=1;
while(1)
{
if(a[i]!=0)//判断元素是否被赋值为0(留在圈子中)
{
g++;
if(g==3)
{
a[i] = 0;//计数到3时,a[i]赋值为0
count++;//记录被赋值为0a[i]的个数
g=0;
if(count==n-1)
{
for(int j=1;j<=n;j++)//从1到n
{
if(a[j]!=0)//如果a[j]没被赋值为0
{
p = &a[j];
printf("%d",*p);
}
}
break;
}
}
}
i++;
if(i==n+1)i=1;//如果到n,从1重新开始
}
/*********End**********/
return 0;
}