#include
int main()
{
int n,i,j,t,l;
int sum=0;
printf("请输入一个大于2的整数:");
scanf("%d",&n);
l=n;
for(;n>=2;n--)
{
for(i=2;i { if(n%i!=0)//判断其为素数 t=1;1 else { t=2; break; } } if(t==1) { sum+=n; //printf("%d ",n);//输出1-n之间的所有素数 } } printf("1-%d之间的所有素数和为:%d\n",l,sum); return 0; } 运行效果: 以15为例: 因为:1-15之间的素数有13、11、7、5、3、2 所以:13+11+7+5+3+2=41 printf()函数用法: printf()函数的调用格式为:printf("<格式化字符串>",<参量表>)。 其中格式化字符串包括两部分内容:一部分是正常字符,这些字符将按原样输出;另一部分是格式化规定字符,以"%"开始,后跟一个或几个规定字符,用来确定输出内容格式。 参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用","分开,且顺序一一对应,否则将会出现意想不到的错误。扩展资料:
# include
int SumPrime(int n)
{
int i;
int k;
int sum=0;
for(i=2;i<=n;++i )
{
for(k=2;k {
if(i%k==0)
break;
}
if(k == i) sum+= k;
}
return sum;
}
int main (void)
{
int n;
int sum;
printf("please enter a number:");
scanf("%d",&n);
sum=SumPrime(n);
printf("sum = %d\n",sum);
return 0;
}
这个问题最好自定义一个函数,然后在主函数上循环执行这个函数并实现累加,具体代码如下:
#include
#include
#include
int IsPrime(int x);
main()
{
int n,j;
int s=0;//用于求和
printf("Input n:");
scanf("%d",&n);
//实现1到n判断是否为素数,并且实现累加
for(j=2;j<=n;j++)
{
if(IsPrime(j))
s+=j;
}
printf("sum=%d\n",s);
system("pause");
}
//函数功能:判断一个数是否为素数
int IsPrime(int x)
{
int flag=1;
int i;
//提高函数的健壮性
if(x<2)
flag=0;
for(i=2;i{
if(x%i==0)
{
flag=0;
break;
}
}
return flag;
}
你的程序中 判断素数并加和的部分有问题 在你的基础上修改如下 PS:main不需要改动 # include int SumPrime(int n){ int i; int k; int sum=0; for(i=2;i
。。。。我也问了类似的题。不过我是写完了。优化时出问题