コンピュータ サイエンスでは、素数は 1 とそれ自体でのみ割り切れる正の整数を指します。素数は、暗号化、数学的導出、アルゴリズムの最適化などの分野で使用できます。実際のアプリケーションでは、素数を見つけるためのアルゴリズムも非常に重要な知識ポイントの 1 つです。今日は、PHP のスクリプトを使用して素数を見つける方法について説明します。
スクリーニング方法は、素数を見つけるための古典的なアルゴリズムです。その中心的な考え方は、素数ではない数値を継続的に除外することです。最後に残ったのは素数です。具体的な手順は次のとおりです。
実装コードは次のとおりです。
function sieve($n) { $prime = array(); for($i = 2; $i <= $n; ++$i) { $prime[$i] = true; } for($i = 2; $i <= sqrt($n); ++$i) { if($prime[$i]) { for($j = $i*$i; $j <= $n; $j += $i) { $prime[$j] = false; } } } return array_keys(array_filter($prime)); }
フェルマーの小定理は、重要な数論の定理です。 used 数値が素数かどうかを判断します。フェルマーの小定理は次のように表されます。p が素数、a が任意の整数の場合、a^(p-1)≡1(mod p) です。
具体的な手順は次のとおりです:
実装コードは次のとおりです:
function is_prime($n) { if($n <= 1) { return false; } for($i = 0; $i < 10; ++$i) { $a = rand(1, $n-1); if(gcd($a, $n) != 1) { return false; } if(mod_pow($a, $n-1, $n) != 1) { return false; } } return true; } function gcd($a, $b) { return ($b == 0) ? $a : gcd($b, $a%$b); } function mod_pow($base, $exp, $modulus) { $result = 1; while($exp > 0) { if($exp % 2 == 1) { $result = ($result * $base) % $modulus; } $exp = $exp >> 1; $base = ($base * $base) % $modulus; } return $result; }
上記は、PHP のスクリプトを使用して素数を見つける 2 つの方法です。広範囲の素数を解く場合、スクリーニング法はフェルマーの小定理よりも効率的な場合が多いことに注意してください。
以上がPHPでスクリプトを使用して素数を見つけるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。