同学们正在练习列队,从第一个人开始按编号1、2、…、n(0<n<1000)报数,开始所有人都是面向前方,第一遍报数是a的倍数的同学执行一遍向后转命令,第二遍报数是b的倍数的同学执行一遍向后转命令,第三遍报数是c的倍数的同学执行一遍向后转命令,其中a、b、c是大于0小于1000的整数。第二和第三遍报数时需要考虑已经向后转的同学再向前转的情况,输入人数n、a、b、c,按顺序输出最终仍然面向前方的同学的编号。
输入格式:
输入4个正整数n、a、b、c。
输出格式:
在一行中输出一个整数列,以空格间隔。
输入样例:
在这里给出一组输入。例如:
10 3 4 5
输出样例:
在这里给出相应的输出。例如:
1 2 7
#include<stdio.h>
int main()
{
int i=1,j=0,n=0,a=0,b=0,c=0;
int m=0,x=0,y=0;
int k[1000]={0};
scanf("%d %d %d %d",&n,&a,&b,&c);
for(i=1;i<=n;i++)
{
if(i%a!=0&&i%b!=0&&i%c!=0)
{
k[m]=i;
m++;
}
else if(((i%a==0)&&(i%b==0))||((i%a==0)&&(i%c==0))||((i%b==0)&&(i%c==0)))
{
k[m]=i;
m++;
}
else {continue;}
}
for(j=0;j<m-1;j++)
{
printf("%d ",k[j]);
}
printf("%d",k[m-1]);
printf("\n");
return 0;
}