原题链接:[编程入门]报数问题
解题思路:
注释都有解释
//报数问题
#pragma warning(disable:4996)
#include <stdio.h>
#define SIZE 81
int no[SIZE];
int n;
int remind(void);
int main(void)
{
int i;
int pace = 0;
scanf("%d", &n);
for (i = 0; i < n; i++)
no[i] = i;
i = 0;
while (1) //循环次数未知
{
if (pace<2 && no[i]!=SIZE) //pace每次第三个人去掉
{
pace++;
i = (i + 1) % n;
}
else if (pace== 2&&no[i]!=SIZE)
{
pace = 0;
no[i] = SIZE;
i = (i + 1) % n;
}
else
{
i = (i + 1) % n;
}
if (remind() == 1) //剩余一个人,直接输出
{
i = 0;
while (no[i] == SIZE)
i++;
i = (i - 1 + n) % n;
printf("%d", no[i]+1);
break;
}
else if (remind() == 2) //剩余两个人,输出第二个报数的
{
while (no[i] == SIZE)
i=(i+1)%n;
i++;
while (no[i] == SIZE)
i = (i + 1) % n;
printf("%d", no[i]+1);
break;
}
else
continue;
}
return 0;
}
int remind(void) //返回值为目前剩余的人数
{
int i;
int nums = 0;
for (i = 0; i < n; i++)
if (no[i] == SIZE)
nums++;
return n - nums;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复