原题链接:[编程入门]报数问题
解题思路:
注释都有解释
//报数问题
#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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
 
发表评论 取消回复