有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;
这一步骤是什么意思?
展开
 我来答
ioyjm01
2012-05-21 · 超过12用户采纳过TA的回答
知道答主
回答量:30
采纳率:0%
帮助的人:14.5万
展开全部
p = a,表示的是p指向的是数组的首地址。n+a表示的数组的尾地址。意思就是如果指针指向数组最后一个数,则跳回到第一个。。。。。就是题目提到的围成一个圈。
百度网友1347a34
2016-04-24 · TA获得超过2558个赞
知道小有建树答主
回答量:497
采纳率:66%
帮助的人:366万
展开全部
#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;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
kkae8643150
2012-05-21
知道答主
回答量:33
采纳率:0%
帮助的人:20.7万
展开全部
p起始值为a的首地址,即指向第1个小盆友。从1到n每个小盆友报数一次p往下偏移一次,当第n个小盆友报数后,p++指向了第n+1个小盆友,即第1个小盆友(围成圈就是这样)。所以p == a + n时,要把它变回a。专业术语叫取模。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式