原题链接:[编程入门]报数问题
解题思路:
创建一个数组盛放报数人序号,报完数后未被pass的人,其序号被扩充到数组结尾等待下次报数
注意事项:
参考代码:
#include<stdio.h> #include<stdlib.h> int main(){ int *num; //创建数组盛放报数的序号 int n,i=1,j,m; //n为参与报数的人数,m是数组长度,i用于依次遍历数组下标,报数为3的人下标是3的倍数 scanf("%d",&n); j=n+1; //j用于盛放每一次报数后未被pass的人的序号 m=2*n; //数组长度初始化,这里初始为人数的2倍 num=(int *)calloc(m,sizeof(int)); for(i=1;;i++){ if(j==m){ m+=10; //当报数的次数达到数组长度时,扩充10个数组长度 num=(int *)realloc(num,m*sizeof(int)); } if(i<=n){ //前n+1个数的下标就是报数人的序号 if(i%3!=0){ num[j]=i; j+=1; } } else{ if(i%3!=0){ num[j]=num[i]; //从j开始下标大于总人数了,所以用数组内容记录报数人的序号 j+=1; } } if(j-i==1) //报数人报完数就要被扩充时,说明是最后报数人,游戏结束 break; } printf("%d",num[i]); free(num); num=NULL; return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复