PHP 求n以内的质数
答案
质数筛选定理:
n
不能够被不大于根号n
的任何质数整除,则n
是一个质数除了
2
,其他偶数都不是质数
/**
* 求n以内的质数
* @param $n int 质数的最大范围
* @return array 质数集合
*/
function primeNumber($n)
{
$prime = array(2); // 2为质数
for ($i = 3; $i <= $n; $i += 2) { // 偶数不是质数,步长可以加大
$sqrt = intval(sqrt($i)); // 求根号n
for ($j = 3; $j <= $sqrt; $j += 2) { // i是奇数,当然不能被偶数整除,步长也可以加大。
if ($i % $j == 0) {
break;
}
}
if ($j > $sqrt) {
array_push($prime, $i);
}
}
return $prime;
}
测试代码:
$res = primeNumber(100);
// 输出:[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97]
echo json_encode($res);