在電腦科學中,質數指的是只能被1和本身整除的正整數。素數可以用於加密,數學推導和演算法最佳化等領域。在實際應用中,求質數的演算法也是非常重要的知識點之一,今天我們就來探討如何用php中用腳本實現求質數。
- 篩選法
篩選法是求質數的經典演算法,其核心思想是不斷地篩選掉不是質數的數,最後留下的就是質數。具體步驟如下:
- 初始化一個素數數組$prime = array(),把2到n(n為要求的範圍)的數字都放進去。
- 對於2~sqrt(n)(sqrt(n)代表n的平方根)的數字,依序判斷是否是質數,如果是,則把它的倍數從素數數組中去掉。
- 循環結束之後,素數數組中剩下的數字就是所有的質數。
實作程式碼如下:
function sieve($n) { $prime = array(); for($i = 2; $i <ol start="2"><li>費馬小定理</li></ol><p>費馬小定理是重要的數論定理,可以用來判斷一個數是否為質數。費馬小定理的陳述如下:若p是質數,a是任意整數,則a^(p-1)≡1(mod p)。 </p><p>具體步驟如下:</p><ol> <li>隨機選擇一個數a,判斷a和n是否互質,如果不互質則直接回傳false。 </li> <li>計算a^(n-1) mod n的值,如果不等於1,則傳回false。 </li> <li>經過多次測試後,如果都滿足上述兩個條件,那麼n很有可能是質數。 </li> </ol><p>實作程式碼如下:</p><pre class="brush:php;toolbar:false">function is_prime($n) { if($n 0) { if($exp % 2 == 1) { $result = ($result * $base) % $modulus; } $exp = $exp >> 1; $base = ($base * $base) % $modulus; } return $result; }
以上就是用php中用腳本實作求素數的兩種方法。需要注意的是,在求解大範圍的質數時,篩選法往往比費馬小定理更有效率。
以上是php中用腳本實作求素數的詳細內容。更多資訊請關注PHP中文網其他相關文章!
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章
<🎜>:種植花園 - 完整的突變指南
3 週前ByDDD
<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前By尊渡假赌尊渡假赌尊渡假赌
如何修復KB5055612無法在Windows 10中安裝?
3 週前ByDDD
北端:融合系統,解釋
3 週前By尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

WebStorm Mac版
好用的JavaScript開發工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具