1. #include<stdio.h>
  2. int main()
  3. {
  4. int a[30000], s = 0, sum = 0, i, n;
  5. scanf("%d", &n);//输入圈内有几个人
  6. for (i = 0; i <= n; i++)
  7. a[i] = 1;//起标记计数作用,是1时,在圈内,是0是在圈外
  8. for (i = 1;; i++)//此处不设结束标志,在循环体内控制,满足条件跳出
  9. {
  10. s = s + a[i];//S计数,满三计数清零 ,同时标记a[i]清零,统计sum加1
  11. if (s == 3)
  12. {
  13. s = 0;
  14. a[i] = 0;
  15. sum++;
  16. }
  17. if (i == n)//判断是不是到了标号最大的人,若是则跳到开始0的地方,循环时,自动加1,又变成1处,从而形成报数的环
  18. i = 0;
  19. if (sum == n - 1)//到N-1是因为要防止最后一个出圈的人在数组的边界,前面的步骤就会一直跳到 a[0],然后就跳出循环,
  20. {
  21. for (i = 1; i <= n; i++)//得不到正确结果,所以在N等于 N-1时遍历一遍找到最后一个标记为1的数即可
  22. if (a[i] == 1)
  23. printf("%d\n", i);
  24. break;
  25. }
  26. }
  27. return 0;
  28. }
点赞(0)
 

9.5 分

4 人评分

 

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

namedgreen 4年前 回复TA
膜拜膜拜