php中用脚本实现求素数
原创在计算机科学中,素数指的是只能被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><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/7fc7563c4182" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">PHP免费学习笔记(深入)</a>”;</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中用脚本实现求素数的详细内容,更多请关注IT视界其它相关文章!
上一篇:php exec 用法 下一篇:php中求数组的长度的函数