sol21
sol21
采纳率80%
2017-05-04 16:23 阅读 4.3k
已采纳

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);
}

图片图片

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

3条回答 默认 最新

  • 已采纳
    blessLZH0108 Alzh 2017-05-05 02:33

    这个if语句应该这样写

      if (a==0)
                {
                    if(j-n1<=2&&j-n1>0)
                    {
                        b++;
                    }
                    n1=j;
                }
    

    你每找到一个素数都要让n1的值改变

    点赞 2 评论 复制链接分享
  • sol21 sol21 2017-05-04 17:37

    描述

    写一个程序,找出给出素数范围内的所有孪生素数的组数。
    一般来说,孪生素数就是指两个素数距离为2,近的不能再近的相邻素数。
    有些童鞋一看到题就开始写程序,不仔细看题,咱们为了遏制一下读题不认真仔细的童鞋。
    规定!!两个素数相邻为1的也成为孪生素数。
    (提醒:1不是素数!)
    (根据题意14之前的孪生素数组有, , , 这4组)

    输入

    第一行给出N(0 < N < 100)表示测试数据组数。
    接下来组测试数据给出m,表示找出m之前的所有孪生素数。
    (0 < m < 1000000)

    输出

    每组测试数据输出占一行,该行为m范围内所有孪生素数组数。

    样例输入

    1
    14

    样例输出

    4

    要求:

    编译时间不得超过 3000 ms, 运行时间不得超过 3000 ms, 内存用量不得超过 10485760 B.

    点赞 1 评论 复制链接分享
  • sol21 sol21 2017-05-04 17:34

    题目要求不知道为什么这么糊,重新发一下图片图片

    点赞 评论 复制链接分享

相关推荐