原题链接:[编程入门]报数问题
解题思路:
创建一个数组盛放报数人序号,报完数后未被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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复