我們如何優化埃拉托斯特尼篩法以在 Python 中高效產生質數?
Nov 28, 2024 pm 12:00 PM埃拉托斯特尼篩法:在Python 中優化素數產生
埃拉托斯特尼篩法是尋找素數的經典演算法。然而,正確實現它以避免效能瓶頸至關重要。
原始實作
提供的 primes_sieve 函數維護候選素數列表並迭代刪除非素數通過遍歷列表並消除因子來求素。由於列表操作的成本很高,這種方法本質上效率很低。
基於字典的最佳化
改良的 primes_sieve1 函數使用字典來儲存素性標誌。雖然比基於列表的方法更快,但它仍然面臨挑戰。它以未定義的順序迭代字典,導致非素數因子的冗餘標記。此外,它將最終的字典轉換為列表,從而產生不必要的開銷。
正確且高效的實現
正確的埃拉托斯特尼篩法演算法利用布爾標誌列表來表明素性。 primes_sieve2 函數將所有數字的標誌初始化為 True,並將 0 和 1 的標誌設為 False。它迭代列表,透過將標誌設為 False 來標記非素數。
這種方法很有效,因為:
- 它使用列表而不是字典,避免了開銷鍵值運算。
- 僅將質因數標記為非質數,減少冗餘操作。
- 它透過從每個質數的平方而不是其雙倍開始來最佳化標記過程。
透過正確實施埃拉托斯特尼篩法,您可以顯著提高素數產生的性能,使其甚至適用於輸入限制較大,例如查找 200 萬以下的素數。
以上是我們如何優化埃拉托斯特尼篩法以在 Python 中高效產生質數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林
兩個點博物館:所有展覽以及在哪裡可以找到它們
3 週前
By 尊渡假赌尊渡假赌尊渡假赌

熱門文章
擊敗分裂小說需要多長時間?
3 週前
By DDD
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
公眾號網頁更新緩存難題:如何避免版本更新後舊緩存影響用戶體驗?
3 週前
By 王林
兩個點博物館:所有展覽以及在哪裡可以找到它們
3 週前
By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)