C++ 素数对(孪生素数)筛选算法实现
好的,我们来解决这个问题。这是一个典型的素数筛选与配对问题。 ## 🔍 问题分析 我们需要找出所有满足以下条件的素数对 `(p, p+2)`: - `p` 和 `p+2` 都是素数 - 两个数都 ≤ x 例如,当 `x = 20` 时,素数对有:(3,5)、(5,7)、(11,13)、(17,19)。 高效的做法是: 1. 使用**埃拉托斯特尼筛法**(Sieve of Eratosthenes)生成所有 ≤ x 的素数。 2. 遍历筛选后的素数,检查当前素数 `p` 和 `p+2` 是否都是素数,且 `p+2 ≤ x`。 3. 输出所有符合条件的素数对。 ## 💻 C++ 代码实现 ```cpp #include <iostream> #include <vector> using namespace std; // 埃拉托斯特尼筛法,返回布尔数组,isPrime[i] = true 表示 i 是素数 vector<bool> sieve(int n) { vector<bool> isPrime(n + 1, true); isPrime[0] = isPrime[1] = false; for (int i = 2; i * i <= n; ++i) { if (isPrime[i]) { for (int j = i * i; j <= n; j += i) { isPrime[j] = false; } } } return isPrime; } int main() { int x; cout << "请输入 x 的值: "; cin >> x; vector<bool> isPrime = sieve(x); cout << "小于等于 " << x << " 的所有素数对为:" << endl; for (int p = 2; p <= x - 2; ++p) { if (isPrime[p] && isPrime[p + 2]) { cout << "(" << p << ", " << p + 2 << ")" << endl; } } return 0; } ``` ## 🧪 示例运行 **输入:** ``` 请输入 x 的值: 30 ``` **输出:** ``` 小于等于 30 的所有素数对为: (3, 5) (5, 7) (11, 13) (17, 19) (29, 31) ``` ## ⚙️ 关键点说明 - 筛法时间复杂度为 O(n log log n),适合处理较大的 x 值(如 10^6 级别)。 - 检查 `p + 2 ≤ x` 的条件直接在循环中通过 `p <= x - 2` 保证,避免越界。 - 输出格式清晰,便于直接核对。 ######[AI问答 | 610点数解答 | 2026-06-05 20:20:40]
- C语言实现:从键盘输入正整数,轻松判断是否为素数(百度文心 | 576点数解答 | 2024-11-10 19:38:17)375
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)408
- Python爬虫:多页图片爬取与本地保存全流程揭秘(字节豆包 | 119点数解答 | 2025-01-05 12:49:42)281
- Python 网页图片爬取代码分析与优化建议:异常处理、路径优化及爬取规则遵守(字节豆包 | 172点数解答 | 2025-01-05 12:50:16)247
- Python爬虫实战:爬取https://file.kole8.com图片全流程优化与注意事项 (字节豆包 | 530点数解答 | 2025-01-05 12:50:26)213
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)371
- Python切片操作巧解经典算法:二维数组90°旋转(阿里通义 | 205点数解答 | 2023-10-31 11:05:29)359
- 揭秘iOS开发:常用算法大集合,提升应用性能与体验!(阿里通义 | 246点数解答 | 2023-11-08 00:43:08)309
- 深入解析:Vue2.x与Vuex3.x渲染器的Diff算法奥秘(阿里通义 | 222点数解答 | 2023-11-09 01:35:41)387
- 突破 long 范围限制:用 BigInteger 类实现超大数字竖式乘法运算( | 555点数解答 | 2024-03-17 10:56:49)387
- 超范围数字乘法:字符串转数组+模拟竖式运算的实现攻略( | 377点数解答 | 2024-03-17 10:58:21)382
- Java 实现:突破 long 范围限制,模拟竖式运算处理大数字乘法( | 14点数解答 | 2024-03-17 10:58:39)361