C++ 素数对猜想

C++ 素数对猜想

 

 

 

 

 

 

我的解法是先将2到n的所有素数全部列出来,再计算。将全部的素数列出来用了一个叫“埃拉托色尼筛法”的方法。

算法参照这里:https://www.sohu.com/a/252674565_614593

 1 #include <iostream>
 2 #include <vector>
 3 #include <cmath>
 4 
 5 using namespace std;
 6 
 7 int main()
 8 {
 9     int n;
10     cin >> n;
11 
12     vector<int> arr;
13     arr.reserve(n+1);
14     for(int i = 2;i <= n;++i)
15     {
16         arr[i] = i;
17     }
18 
19     double a = sqrt(n);
20     //得到所有的素数
21     for(int i = 2;i <= a ;++i)
22     {
23         for(int j = 2;j*i <=n;j++)
24         {
25             arr[i*j] = 0;
26         }
27     }
28 
29     int time = 0;
30     for(int i = 2;i+2 <= n;++i)
31     {
32         if(arr[i+2]-arr[i] == 2)
33         {
34             time++;
35         }
36     }
37     cout << time;
38     return 0;
39 }

 

原文链接: https://www.cnblogs.com/apprendre-10-28/p/12732268.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    C++ 素数对猜想

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/343053

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月2日 上午1:55
下一篇 2023年3月2日 上午1:55

相关推荐