有n个人围成一圈,按顺序从1到n编号。从第一个人开始报数,报数3的人退出圈子,下一个人从1开始重新报数, 5
#include<stdio.h>#defineN100intmain(){inti,j=1,n,a[N],*p=a,count=0;printf("Inputn(nmu...
#include <stdio.h>
#define N 100
int main()
{
int i,j=1,n,a[N],*p=a,count=0;
printf("Input n(n must be a natural number less than 10000):");
scanf("%d",&n);
for(i=0;i<n;i++)
a[i]=i+1;
while(j<n){
if(*p!=0) count++;
if(count==3) {
*p=0;
count=0;
j++;
}
p++;
if(p==n+a) p=a;
}
for(i=0;i<n;i++)
if(*p!=0)
printf("%d",a[i]);
return 0;
}
if(p==n+a) p=a;
这一步骤是什么意思? 展开
#define N 100
int main()
{
int i,j=1,n,a[N],*p=a,count=0;
printf("Input n(n must be a natural number less than 10000):");
scanf("%d",&n);
for(i=0;i<n;i++)
a[i]=i+1;
while(j<n){
if(*p!=0) count++;
if(count==3) {
*p=0;
count=0;
j++;
}
p++;
if(p==n+a) p=a;
}
for(i=0;i<n;i++)
if(*p!=0)
printf("%d",a[i]);
return 0;
}
if(p==n+a) p=a;
这一步骤是什么意思? 展开
3个回答
展开全部
#include <stdio.h>
const int M = 3;
int main()
{
int n, s = 0;
scanf("%d", &n);
for (int i = 2; i <= n; ++i)
s = (s+M)%i;
printf("%d\n", s+1);
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
p起始值为a的首地址,即指向第1个小盆友。从1到n每个小盆友报数一次p往下偏移一次,当第n个小盆友报数后,p++指向了第n+1个小盆友,即第1个小盆友(围成圈就是这样)。所以p == a + n时,要把它变回a。专业术语叫取模。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询