#include<stdio.h>
#include<math.h>
int main()
{
int i,j,m,n,k;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
k=int(sqrt(i));
for(j=2;j<k;j++)
if(i%j==0) break;
if(j>k) printf("%d\n",i);
else break;
}
return 0;
}
4 回答
葛zc
TA贡献3条经验 获得超2个赞
if(j>k) printf("%d\n",i);
else break;
这代码的意思是如果i是素数,输出i,不是的话跳出for(i=1;i<=n;i++)这循环所以错了,应该去掉 else break;
慕少1414285
TA贡献4条经验 获得超0个赞
#include<stdio.h>
#include<math.h>
int prime(int x){
int i;
for(i=2;i<=(int)sqrt(x);i++)
if(x%i==0)
return 0;
return 1;
}
void main(){
int n,i,j;
printf("n=");
scanf("%d",&n);
printf("小于等于%d的素数\n",n);
if(n>2){
printf("%4d",2);
j++;
}
for(i=3;i<=n;i+=2)
if(prime(i)==1){
printf("%4d",i);
if(j!=0 && ++j%10==0)
printf("\n");
}
printf("\n");
}
慕尼黑1170528
TA贡献10条经验 获得超2个赞
#include<stdio.h> #include<math.h> int main() { int i,j,m,n,k; int flag; scanf("%d",&n); for(i=2;i<=n;i++) { flag = 1; k=int(sqrt(i)); for(j=2;j<=k;j++) { if(i%j==0) { flag = 0; break; } } if (flag) { printf("%d\n", i); } } return 0; }
你都没有想明白你的逻辑怎么来的
- 4 回答
- 0 关注
- 2546 浏览
添加回答
举报
0/150
提交
取消