解题思路:建议用flag语句做判断,数组1、0开关
注意事项:
参考代码:
#include<stdio.h>
#define maxSize 50001
int main()
{
int arr[maxSize];
int n,i,j,m;
scanf("%d %d",&n,&m);
int flag=0;
for(i=1;i<=n;i++)
{
arr[i]=1; //初始是开启状态,为1
}
for(i=1;i<=m;i++) //m个人操作
{
for(j=i;j<=n;j=j+i)
{
arr[j]=-1*arr[j]; //每次操作取反
}
}
for(i=1;i<=n;i++)
{
if (arr[i]==-1)
{
if(flag==0)
{
printf("%d",i);
flag = 1;
}
else
{
printf(",%d",i);
}
}
}
return 0;
}
0.0分
0 人评分
C语言考试练习题_保留字母 (C语言代码)浏览:686 |
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:619 |
【计算两点间的距离】 (C语言代码)浏览:883 |
【绝对值排序】 (C++代码)浏览:672 |
2003年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:750 |
剪刀石头布 (C语言代码)浏览:751 |
简单的a+b (C语言代码)浏览:478 |
DNA (C语言代码)浏览:747 |
C二级辅导-等差数列 (C语言代码)浏览:695 |
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:1233 |