用C语言编一程序,输出200~300之间的全部素数,求解啊

如题所述

#include<iostream>

usingnamespacestd;

intHaveFun()

intSum=0;

for(intvar=200;var<=300;var++){

boolisPrime=1;

for(intfac=2;fac*fac<=var;fac++)

if(!(var%fac))isPrime=0;

if(isPrime)Sum+=var;

returnSum;

intmain()

cout<<HaveFun()<<endl;

return0;

方法二、

扩展资料:

return 0用法:

return 0代表程序正常退出。return是C++预定义的语句,它提供了终止函数执行的一种方式。当return语句提供了一个值时,这个值就成为函数的返回值

return语句用来结束循环,或返回一个函数的值。

1、return 0,说明程序正常退出,返回到主程序继续往下执行。

2、return 1,说明程序异常退出,返回主调函数来处理,继续往下执行。return 0或return 1对程序执行的顺序没有影响,只是大家习惯于使用return(0)退出子程序而已。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2007-06-07
楼上的楼上算法可以改进:
第一,200以上偶数一定不是素数
第二,17*17=289,就是说,300以内的合数,最小的因子最大只能是17。所以,程序可以改为下面这种,计算时间将大大地减少:
#include <stdio.h>
void main()
{
int i,k;
for (i=201;i<300;i=i+2)
{
if(i%3!=0 && i%5!=0 && i%7!=0 && i%11!=0 && i%13!=0 && i%17!=0)
printf("%d ",i);
}
}
就可以了。循环比原来减少一半每次循环一共只要比6次。
第2个回答  2011-12-03
可以对楼上代码优化一下
#include <stdio.h>
#include <math.h>
int main()
{
int i,j;
for(i=200;i<300;i++)
{
for(j=2;j<i;j++)
if(i%j==0)
break;
if( j>sqrt(i) )
printf("%d\n",i);
}
return 0;
}
第3个回答  2011-12-02
~好用啊
#include<stdio.h>
void main()
{
int n,i;
for(n=200;n<300;n++)
{
for(i=2;n%i;i++);
if(n==i)
printf("%5d",i);
}
}
第4个回答  2011-12-02
#include <stdio.h>

int isPrime(int num) {

int divisor = 3;
int testLimit = num;
if (num % 2 == 0) return 2;
while ( testLimit > divisor )
{
if ( num % divisor == 0 )
{
return 3;
}
testLimit = num / divisor;
divisor += 2;
}
return 1;
}
int main()
{
int i = 0;
int iFlag = 0;
for (i=200; i<300; i++)
{
iFlag = isPrime(i);
if (iFlag==1)
{
printf("%d ", i);
}
}
}