孪生素数问题
时间限制:
3000
ms | 内存限制:
65535
KB
难度:
3
-
描述
-
写一个程序,找出给出素数范围内的所有孪生素数的组数。一般来说,孪生素数就是指两个素数距离为2,近的不能再近的相邻素数。有些童鞋一看到题就开始写程序,不仔细看题,咱们为了遏制一下读题不认真仔细的童鞋,规定,两个素数相邻为1的也成为孪生素数。
-
输入
-
第一行给出N(0<N<100)表示测试数据组数。
接下来组测试数据给出m,表示找出m之前的所有孪生素数。
(0<m<1000000)
输出
- 每组测试数据输出占一行,该行为m范围内所有孪生素数组数。 样例输入
-
1 14
样例输出
-
4
来源
- [hzyqazasdf]原创 上传者
- hzyqazasdf
-
第一行给出N(0<N<100)表示测试数据组数。
用筛选法求素数应该算是比较基础的题了,水题~,这道题开始题意没看清,(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的。好像是用打表做的。。有点没看懂啊。。。基础还是不扎实啊。。继续努力啊!!!!程序的优化也很重要啊!!