c语言关于孪生素数问题

以下为代码……不知道哪里错了,我自己调试的时候结果好像是对的啊,求帮忙看看

#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.