以下为代码……不知道哪里错了,我自己调试的时候结果好像是对的啊,求帮忙看看
#include
#include
void main()
{
int a=0,b,i,j,x,n,n1;
long *s=0;
scanf("%ld",&n);
s=(long*)malloc(sizeof(long)*(n+2));
for(i=0;i<n;i++)
scanf("%d",&s[i]);
for(i=0;i<n;i++)
{
b=0;
n1=2;
for (j=3;j<s[i];j++)
{a=0;
for(x=2;x<j;x++)
{
if (j%x==0)
{
a=1;
break;
}
}
if (a==0&&j-n1<=2&&j-n1>0)
{ b++;
n1=j;}
}
printf("%d\n",b);
}
free(s);
}
这个if语句应该这样写
if (a==0)
{
if(j-n1<=2&&j-n1>0)
{
b++;
}
n1=j;
}
你每找到一个素数都要让n1的值改变
描述
写一个程序,找出给出素数范围内的所有孪生素数的组数。
一般来说,孪生素数就是指两个素数距离为2,近的不能再近的相邻素数。
有些童鞋一看到题就开始写程序,不仔细看题,咱们为了遏制一下读题不认真仔细的童鞋。
规定!!两个素数相邻为1的也成为孪生素数。
(提醒:1不是素数!)
(根据题意14之前的孪生素数组有, , , 这4组)
输入
第一行给出N(0 < N < 100)表示测试数据组数。
接下来组测试数据给出m,表示找出m之前的所有孪生素数。
(0 < m < 1000000)
输出
每组测试数据输出占一行,该行为m范围内所有孪生素数组数。
样例输入
1
14
样例输出
4
要求:
编译时间不得超过 3000 ms, 运行时间不得超过 3000 ms, 内存用量不得超过 10485760 B.