C++利用用埃式篩法求解素?cái)?shù)
埃式篩法
首先要了解什么式埃式篩法之前,需要知道一個(gè)定理。
就是素?cái)?shù)的整數(shù)倍一定不是素?cái)?shù)。
了解了這個(gè)就基本大概懂了埃式篩法。
- 首先初始化一個(gè)布爾數(shù)組is_prime,用于記錄每個(gè)數(shù)是否為素?cái)?shù)。
- 從2開(kāi)始,枚舉每個(gè)數(shù)i,如果is_prime[i]為true,則i是素?cái)?shù),添加到素?cái)?shù)數(shù)組primes中。
- 然后對(duì)于每個(gè)i,我們讓我擴(kuò)大j倍,直到i*j小于輸入的數(shù)字n,把is_prime[i * j]賦值為false。
- 重復(fù)步驟2和3,直到遍歷到n為止。
埃式篩法求解某一個(gè)數(shù)字包含的所有素?cái)?shù)數(shù)組
Code
#include <iostream> #include <vector> #include <ctime> using namespace std; vector <int> sieve_of_eratosthenes(int n) { vector <int> primes; vector <bool> is_prime(n + 1, true); is_prime[0] = is_prime[1] = false; for (int i = 2; i <= n; i++) { if (is_prime[i]) { primes.push_back(i); } for (int j = 2; i * j <= n; j++) { is_prime[i * j] = false; } } return primes; } int main() { clock_t start, end; start = clock(); int n; cout << "Please Enter n: "; cin >> n; vector <int> primes = sieve_of_eratosthenes(n); cout << "Primes: "; for (int prime : primes) { cout << prime << " "; } cout << "\n素?cái)?shù)個(gè)數(shù)為" << primes.size() << "個(gè)\n"; end = clock(); cout << "The run time is: " << (double)(end - start) / CLOCKS_PER_SEC << "s" << endl; return 0; }
運(yùn)行結(jié)果
埃式篩法判斷某一個(gè)數(shù)字是否為素?cái)?shù)
Code
#include <iostream> #include <vector> #include <ctime> using namespace std; // 埃式篩法求解素?cái)?shù) bool sieve_of_eratosthenes(int n) { vector <bool> is_prime(n + 1, true); is_prime[0] = is_prime[1] = false; for (int i = 2; i <= n; i++) { if (is_prime[i] && i == n) { return true; } for (int j = 2; i * j <= n; j++) { is_prime[i * j] = false; if (i * j == n) { return false; } } } } int main() { clock_t start, end; start = clock(); int n; cout << "Please Enter n: "; cin >> n; if (sieve_of_eratosthenes(n)) { cout << n << "是素?cái)?shù)!!!"; } else { cout << n << "不是素?cái)?shù)..."; } end = clock(); cout << "The run time is: " << (double)(end - start) / CLOCKS_PER_SEC << "s" << endl; return 0; }
運(yùn)行結(jié)果
到此這篇關(guān)于C++利用用埃式篩法求解素?cái)?shù)的文章就介紹到這了,更多相關(guān)C++求解素?cái)?shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)源代碼
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言學(xué)生成績(jī)管理系統(tǒng)源代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03C語(yǔ)言實(shí)現(xiàn)車(chē)票管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)車(chē)票管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05C++中關(guān)于constexpr函數(shù)使用及說(shuō)明
這篇文章主要介紹了C++中關(guān)于constexpr函數(shù)使用及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11C++設(shè)計(jì)模式之Proxy模式(代理模式)詳解
這篇文章主要為大家詳細(xì)介紹了C++設(shè)計(jì)模式之Proxy模式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07詳解MFC/C++調(diào)用易語(yǔ)言的整數(shù)型和文本型與VS2010互動(dòng)
在本篇文章里我們給大家分享了MFC/C++調(diào)用易語(yǔ)言的整數(shù)型和文本型與VS2010互動(dòng)相關(guān)知識(shí)點(diǎn)內(nèi)容,有興趣的朋友們可以參考下。2018-11-11C++實(shí)現(xiàn)中綴表達(dá)式轉(zhuǎn)化為后綴表達(dá)式詳解
這篇文章主要為大家詳細(xì)介紹了如何利用C++解決實(shí)現(xiàn)中綴表達(dá)式轉(zhuǎn)換為后綴表達(dá)式的問(wèn)題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03C++之string類(lèi)對(duì)象的容量操作詳解
通過(guò)在網(wǎng)站上的資料搜集,得到了很多關(guān)于string類(lèi)對(duì)象的容量操作,通過(guò)對(duì)這些資料的整理和加入一些自己的代碼,希望能夠給你帶來(lái)幫助2021-08-08