nyist 26 孪生素数问题(筛选法)



孪生素数问题

时间限制: 3000  ms  |  内存限制: 65535  KB
难度: 3
描述
写一个程序,找出给出素数范围内的所有孪生素数的组数。一般来说,孪生素数就是指两个素数距离为2,近的不能再近的相邻素数。有些童鞋一看到题就开始写程序,不仔细看题,咱们为了遏制一下读题不认真仔细的童鞋,规定,两个素数相邻为1的也成为孪生素数。
输入
第一行给出N(0<N<100)表示测试数据组数。
接下来组测试数据给出m,表示找出m之前的所有孪生素数。
(0<m<1000000)
输出
每组测试数据输出占一行,该行为m范围内所有孪生素数组数。
样例输入
1
14
样例输出
4
来源
[hzyqazasdf]原创
上传者
hzyqazasdf


用筛选法求素数应该算是比较基础的题了,水题~,这道题开始题意没看清,(m范围内包括m。。。)开始就wa了三次,后面就涉及到优化的问题。

第一次a的代码,用了两个数组

#include <stdio.h>
#define MAXN 1000010
int s[MAXN],temp[MAXN];
int main()
{
   int n,m,i,j,count,k;
   for(i=2;i<MAXN;i++)//对数组进行初始化
     s[i]=0;
   for(i=2;i<MAXN;i++)//筛选法,一个数如果是素数,那么他的倍数就肯定不是素数
   {
       if(s[i]==0)
        for(j=i+i;j<MAXN;j+=i)
         s[j]=1;
   }
    scanf("%d",&n);
   while(n--)
   {
       count=0;
       scanf("%d",&m);
       for(i=2,k=0;i<=m;i++)//m之内,包括m..(就这个地方没加等号,wa了三次)
       {
           if(s[i]==0)
            temp[k++]=i;
       }
       for(i=0;i<k;i++)
       {
           if(temp[i+1]-temp[i]==2||temp[i+1]-temp[i]==1)
              count++;
       }
       printf("%d\n",count);
   }
    return 0;
}

第二次优化的代码,只用一个数组

#include <stdio.h>
#define MAXN 1000010
int s[MAXN];
int main()
{
   int n,m,i,j,count;
   for(i=2;i<MAXN;i++)
     s[i]=0;
   for(i=2;i<MAXN;i++)
   {
       if(s[i]==0)
        for(j=i+i;j<MAXN;j+=i)
         s[j]=1;
   }
    scanf("%d",&n);
   while(n--)
   {
       count=0;
       scanf("%d",&m);
       for(i=2;i<=m;i++)
       {
           if((s[i]==0&&s[i+2]==0&&i+2<=m)||(s[i]==0&&s[i+1]==0&&i+1<=m))//这里用了几个逻辑运算
            count++;
       }
       printf("%d\n",count);
   }
    return 0;
}
第二次的比前面的精简一点。内存少了。但是用时却多了。感觉逻辑运算用多了还是消耗时间啊。。  还看了一些大神的代码。。有只有10.20ms的。好像是用打表做的。。有点没看懂啊。。。基础还是不扎实啊。。继续努力啊!!!!程序的优化也很重要啊!!

你可能感兴趣的:(nyist)