C語言--求n以內的素數(質數)

求n以內的素數,可以用試除法或者埃拉托斯特尼篩法(埃氏篩法)

文章目錄

  • 試除法
  • 埃拉托斯特尼篩法(埃氏篩法)
  • 兩種方法測試
    • 運行效率

輸入:數字n
輸出:n以內所有的素數

不管是哪個方法,都有一個數學結論可以減少循環次數:

如果有一個數不是質數,那么它至少有一個因子小于等于他的平方根。所以說n有因數的話,一定有一個小于根號n,因此只需要看遍歷到根號n即可。
反過來說,如果根號n內沒有某個數的因數,那么整個2,n-1都沒有這個數的因數。

試除法

使用i*i而不是sqrt(n)是為了避免對浮點數進行處理。

/**
*  試除法
*  0、1 都不是質數
*  如果有一個數不是質數,那么它至少有一個因子小于等于他的平方根
*  算法效率從n變為根號n
*/
int isPrime(int n){if(n<2) {return 0;}for(int i=2;i*i<=n;i++){if(n%i==0){return 0;}}return 1;
}
void findPrimesByTrialDivision(int n){for (int i = 2; i <= n; i++) {if (isPrime(i)) {printf("%d\t", i);}}printf("\n");
}

埃拉托斯特尼篩法(埃氏篩法)

質數的倍數一定是非質數。從而逐步將非質數排除。
由于:如果有一個數不是質數,那么它至少有一個因子小于等于他的平方根。
所以:外層循環從2-根號n,內層循環從i*i開始。

void Eratosthenes(int n){int *isPrime = calloc(n+1,sizeof(int));for(int i=2;i<=n;i++){// 初始化所有數都是質數isPrime[i] = 1;}for(int i=2; i*i<=n;i++){if(isPrime[i]){for(int j=i*i;j<=n;j+=i){isPrime[j] = 0;}}}for (int i = 2; i <= n; i++) {if (isPrime[i]==1) {printf("%d\t", i);}}printf("\n");
}

兩種方法測試

int main(){int n=20;Eratosthenes(n);findPrimesByTrialDivision(n);return 0;
}

在這里插入圖片描述

運行效率

我們把打印質數的代碼刪掉,打印下運行時間

int main() {int n = 6000000;start = clock();Eratosthenes(n);finish = clock();time1 = (double) (finish - start) / CLOCKS_PER_SEC;printf("埃氏篩法所用時間: %f\n", time1);start = clock();findPrimesByTrialDivision(n);finish = clock();time2= (double) (finish - start) / CLOCKS_PER_SEC;printf("試除法所用時間: %f\n", time2);return 0;
}

可以看到埃氏篩法確實在數據量大的的時候效率更高。
在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901011.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901011.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901011.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Skynet.socket 函數族使用詳解

目錄 Skynet.socket 函數族使用詳解核心功能分類一、TCP 連接管理1. 監聽端口2. 建立連接3. 關閉連接 二、數據讀寫操作1. 阻塞式讀取2. 寫入數據2.1 socket.write(fd, data) 的返回值2.2 示例代碼2.3 關鍵注意事項2.4 與其他函數的區別2.5 底層原理2.6 總結 三、UDP 處理1. 創…

Unity Addressables資源生命周期自動化監控技術詳解

一、Addressables資源生命周期管理痛點 1. 常見資源泄漏場景 泄漏類型典型表現檢測難度隱式引用泄漏腳本持有AssetReference未釋放高異步操作未處理AsyncOperationHandle未釋放中循環依賴泄漏資源相互引用無法釋放極高事件訂閱泄漏未取消事件監聽導致對象保留高 2. 傳統管理…

aws(學習筆記第三十八課) codepipeline-build-deploy-github-manual

文章目錄 aws(學習筆記第三十八課) codepipeline-build-deploy-github-manual學習內容:1. 整體架構1.1 代碼鏈接1.2 全體處理架構2. 代碼分析2.1 創建`ImageRepo`,并設定給`FargateTaskDef`2.2 創建`CodeBuild project`2.3 對`CodeBuild project`賦予權限(`ECR`的`image rep…

在windows服務器使用Nginx反向代理云端的python實現的web應用

近日得閑&#xff0c;計劃將之前寫過的一些小桌面程序搬到云服務器上方便隨時隨地使用&#xff0c;同時也學習一些基本的網站開發和搭建知識&#xff0c;于是在AI的幫助下&#xff0c;基于niceguifastapi非常快捷地搞出來了一個前后端一體的網站程序&#xff0c;放在云服務器上…

全球貿易戰火重燃:50%關稅如何絞殺跨境電商低價模式?

一、政策高壓&#xff1a;美國對華貿易戰升級路線圖 2024年5月&#xff0c;美國國會《數字貿易壁壘法案》草案曝光&#xff0c;標志著中美貿易博弈進入新階段&#xff1a; ? 關稅武器精準打擊&#xff1a;成衣、消費電子、小家電稅率擬從10-25%躍升至50% ? 監管范圍擴大&…

0411 | 軟考高項筆記:項目立項

在軟考的項目管理知識體系中&#xff0c;技術可行性和經濟可行性是項目立項階段非常重要的兩個分析維度。以下是對這兩個考點的詳細解釋和記憶方法&#xff1a; 技術可行性分析 定義&#xff1a; 技術可行性分析是評估項目在現有技術條件和資源下是否能夠成功實施。它主要回答…

二分查找3:69. x 的平方根

鏈接&#xff1a;69. x 的平方根 - 力扣&#xff08;LeetCode&#xff09; 題解&#xff1a; 本題本質是二分查找右端點 x的算數平方根一定在1 ~ x 區間內&#xff0c;在1 ~ x區間內查找一個數num&#xff0c;num^2x&#xff0c;但實際上num不一定是整數&#xff0c;所以是n…

oracle大師認證證書有用嗎

專業能力的高度認可&#xff1a;OCM 是 Oracle認證的最高級別&#xff0c;是對數據庫從業人員技術、知識和操作技能的最高級認可&#xff0c;也是 IT 界頂級認證之一。它表明持證者具備處理關鍵業務數據庫系統和應用的能力&#xff0c;能夠解決最困難的技術難題和最復雜的系統故…

InnoDB 如何解決幻讀:深入解析與 Java 實踐

在數據庫事務管理中&#xff0c;幻讀&#xff08;Phantom Read&#xff09;是并發操作中常見的問題&#xff0c;可能導致數據一致性異常。MySQL 的 InnoDB 存儲引擎通過其事務隔離機制和多版本并發控制&#xff08;MVCC&#xff09;&#xff0c;有效解決了幻讀問題。作為 Java …

【AI編程技術爆發:從輔助工具到生產力革命】

目錄 前言&#xff1a;技術背景與價值當前技術痛點解決方案概述目標讀者說明 一、技術原理剖析核心概念圖解關鍵技術模塊技術選型對比 二、實戰演示環境配置要求核心代碼實現運行結果驗證 三、性能對比測試方法論量化數據對比&#xff08;2023年數據&#xff09;結果分析 四、最…

ICRA-2025 | 視覺預測助力機器人自主導航!NavigateDiff:視覺引導的零樣本導航助理

論文&#xff1a;Yiran Qin 1 , 2 ^{1,2} 1,2, Ao Sun 2 ^{2} 2, Yuze Hong 2 ^{2} 2, Benyou Wang 2 ^{2} 2, Ruimao Zhang 1 ^{1} 1單位&#xff1a; 1 ^{1} 1中山大學&#xff0c; 2 ^{2} 2香港中文大學深圳校區論文標題&#xff1a;NavigateDiff: Visual Predictors are Ze…

【ESP32S3】GATT Server service table傳送數據到調試助手

前言 在初步學習esp32藍牙的過程中&#xff0c;借鑒了官方的GATT Server Service Table Example&#xff0c;可以在readme中看到&#xff0c;此demo是采用低功耗藍牙的通用屬性服務器來創建訂閱服務和特性。如果你接觸過MQTT&#xff0c;你會發現GATT Server這一特性和MQTT的訂…

DeepSeek :中國 AI 如何用 “小米加步槍” 逆襲硅谷

2025 年春節前夕&#xff0c;人工智能領域誕生了一項重大成果 ——DeepSeek 發布DeepSeek - R1 大模型。這一模型迅速引發廣泛關注&#xff0c;在蘋果 AppStore 中國區免費榜登頂。 DeepSeek 采用開源策略&#xff0c;依據寬松的 MIT 許可證&#xff0c;公開了模型權重、訓練方…

關稅擾動下市場波動,如何尋找確定性的長期之錨?

近期的關稅紛爭&#xff0c;擾動全球資本市場下行。A股市場一度大幅下跌。但隨著各大主力下場&#xff0c;有關部委發布有關有力措施&#xff0c;A股逐步穩住陣腳。 4月8日至4月10日&#xff0c;大盤指數連續3天上漲&#xff0c;上漲120多點&#xff0c;展現出較強的抵御關稅壁…

NeuroImage:膝關節炎如何影響大腦?靜態與動態功能網絡變化全解析

膝骨關節炎&#xff08;KOA&#xff09;是導致老年人活動受限和殘疾的主要原因之一。這種疾病不僅引起關節疼痛&#xff0c;還會顯著影響患者的生活質量。然而&#xff0c;目前對于KOA患者大腦功能網絡的異常變化及其與臨床癥狀之間的關系尚不清楚。 2024年4月10日&#xff0c;…

【KWDB 創作者計劃】KWDB 數據庫全維度解析手冊

——從原理到實踐&#xff0c;構建下一代數據基礎設施 ?第一章&#xff1a;KWDB 設計哲學與技術全景 1.1 為什么需要 KWDB&#xff1f; 在數據爆炸與業務場景碎片化的今天&#xff0c;傳統數據庫面臨三大挑戰&#xff1a;?擴展性瓶頸?&#xff08;單機性能天花板&#xff…

一個批量文件Dos2Unix程序(Microsoft Store,開源)

這個程序可以把整個目錄的文本文件改成UNIX格式&#xff0c;源碼是用C#寫的。 目錄 一、從Microsoft Store安裝 二、從github獲取源碼 三、功能介紹 3.1 運行 3.2 瀏覽 3.3 轉換 3.4 轉換&#xff08;無列表&#xff09; 3.5 取消 3.6 幫助 四、源碼解讀 五、討論和…

std::string` 類

以下是對 std::string 類中 修改操作 和 字符串操作 的示例代碼&#xff0c;幫助你更好地理解這些函數的使用&#xff1a; 5. 修改操作 (1) operator 用于追加字符串、C 風格字符串或字符。 #include <iostream> #include <string>int main() {std::string str …

《Spring Boot+策略模式:企業級度假訂單Excel導入系統的架構演進與技術實現》

前言 在數字化時代背景下&#xff0c;訂單管理系統的高效性與靈活性成為企業競爭力的核心要素。本文檔詳細剖析了一個基于 策略模式 的度假訂單導入系統&#xff0c;通過分層架構設計實現了多源異構數據的標準化處理。系統以 Spring Boot 為核心框架&#xff0c;結合 MyBatis …

SSRF漏洞公開報告分析

文章目錄 1. SSRF | 獲取元數據 | 賬戶接管2. AppStore | 版本上傳表單 | Blind SSRF3. HOST SSRF一、為什么HOST修改不會影響正常訪問二、案例 4. Turbonomic 的 終端節點 | SSRF 獲取元密鑰一、介紹二、漏洞分析 5. POST | Blind SSRF6. CVE-2024-40898利用 | SSRF 泄露 NTL…