让我们定义dn为:dn=pn+1−pn,其中pi是第i个素数。显然有d1=1,且对于n>1有dn是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。
现给定任意正整数N
(<105),请计算不超过N
的满足猜想的素数对的个数。
输入格式:
输入在一行给出正整数N
。
输出格式:
在一行中输出不超过N
的满足猜想的素数对的个数。
输入样例:
20
输出样例:
4
分析:把0-n的素数都存放在一个数组中,计算数组中相邻两个数的差,若为2,则Flag++,最后输出Flag的值~
#include<stdio.h>
#include<stdbool.h>
#include<math.h>
bool IsPrime(int n){//判断是否为素数
int i,sum=0;
for(i=2;i<=sqrt(n);i++)
if(n%i==0) sum++;
if(!sum) return true;
else return false;
}
int main(){
int N,i,prime[10000],n=0;
scanf("%d",&N);
for(i=2;i<=N;i++)
if(IsPrime(i)){
prime[n]=i;
n++;
}
int k,l,Flag=0;
for(k=0,l=1;l<=n;k++,l++)
if(prime[l]-prime[k]==2)
Flag++;
printf("%d",Flag);
return 0;
}