题目
让我们定义 d~n~ 为:d~n~ = p~n+1~ - p~n~,其中 p~i~ 是第i个素数。显然有 d~1~=1 且对于n>1有 d~n~ 是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。现给定任意正整数N (< 10^5),请计算不超过N的满足猜想的素数对的个数。
输入格式:每个测试输入包含1个测试用例,给出正整数N。
输出格式:每个测试用例的输出占一行,不超过N的满足猜想的素数对的个数。
输入样例:
20输出样例:
4
解析
首先用线性筛法打出来质数表,然后判断质数表相邻的两个是否差为2即可
需要注意的是,遍历质数表有两个条件:
- 在质数表的可判断范围内
- 不超过输入的n
代码
C++解法
#include <cstring> #include <iostream> using namespace std; const int maxn = 1e5 + 5; int prime[maxn]; bool isPrime[maxn]; int pos; void listPrime(int maxNum) { memset(isPrime, true, sizeof(isPrime)); isPrime[0] = isPrime[1] = false; pos = 0; for (int i = 2; i <= maxNum; ++i) { if (isPrime[i]) prime[pos++] = i; for (int j = 0; j < pos && i * prime[j] <= maxNum; ++j) { isPrime[i * prime[j]] = false; if (!(i % prime[j])) break; } } } int ans[maxn]; int main() { cin.tie(0); cin.sync_with_stdio(false); int n; cin >> n; listPrime(n); int cnt = 0; for (int i = 1; prime[i] <= n && i < pos; ++i) { if (prime[i] - prime[i - 1] == 2) cnt++; } cout << cnt << endl; return 0; }
Python解法
def listPrime(MAX): isPrime = [True for i in range(MAX + 1)] isPrime[0] = isPrime[1] = False prime = [] for i in range(2, MAX + 1): if isPrime[i]: prime.append(i) for j in range(0, len(prime)): if i * prime[j] > MAX: break isPrime[i * prime[j]] = False if not (i % prime[j]): break return prime n = int(input()) prime = listPrime(n) cnt = 0 i = 1 while 1: if i >= len(prime) or prime[i] > n: break if prime[i] - prime[i - 1] == 2: cnt += 1 i += 1 print(cnt)
Java解法
import java.lang.reflect.Array; import java.util.*; class Main { public static final int maxn = 100005; public static int[] prime = new int[maxn]; public static boolean[] isPrime = new boolean[maxn]; public static int pos; public static void listPrime(int maxNum) { Arrays.fill(isPrime, true); isPrime[0] = isPrime[1] = false; pos = 0; for (int i = 2; i <= maxNum; ++i) { if (isPrime[i]) prime[pos++] = i; for (int j = 0; j < pos && i * prime[j] <= maxNum; ++j) { isPrime[i * prime[j]] = false; if (i % prime[j] == 0) break; } } } public static void main(String[] args) { Scanner in = new Scanner(System.in); int n = in.nextInt(); listPrime(n); int cnt = 0; for (int i = 1; i < pos && prime[i] <= n; ++i) { if (prime[i] - prime[i - 1] == 2) cnt++; } System.out.println(cnt); in.close(); } }