0

0

PHP函数怎样写一个判断是否为质数的函数 PHP函数质数判断的入门编写教程​

爱谁谁

爱谁谁

发布时间:2025-08-11 20:42:02

|

622人浏览过

|

来源于php中文网

原创

判断一个数是否为质数的核心是检查其是否仅能被1和自身整除,1. 使用基础函数时只需循环到sqrt($number)以减少计算量;2. 优化方法包括排除偶数并利用6k±1的形式跳过非质数;3. 对大数应采用miller-rabin等概率算法结合bcmath扩展提高效率;4. 生成质数数组可结合isprime函数逐个判断并存储,适用于需预生成质数列表的场景,该方法完整有效。

PHP函数怎样写一个判断是否为质数的函数 PHP函数质数判断的入门编写教程​

判断一个数是否为质数,核心在于检查它除了1和自身之外,是否还能被其他数整除。一个简单的PHP函数就能搞定这个任务。

function isPrime(int $number): bool {
  if ($number <= 1) {
    return false;
  }

  for ($i = 2; $i <= sqrt($number); $i++) {
    if ($number % $i === 0) {
      return false;
    }
  }

  return true;
}

// 示例用法
$num = 29;
if (isPrime($num)) {
  echo $num . " 是质数。";
} else {
  echo $num . " 不是质数。";
}

PHP判断质数函数:如何提高效率?

首先,最直观的优化就是减少循环次数。没必要一直循环到

$number - 1
,只需要循环到
sqrt($number)
即可。 这是因为如果一个数有大于其平方根的因子,那么必然有一个小于其平方根的因子。 比如,判断100是不是质数,你只需要检查到10即可,因为如果存在大于10的因子,比如20,那必然存在一个小于10的因子,也就是5。

立即学习PHP免费学习笔记(深入)”;

其次,可以排除偶数。 除了2以外,没有偶数是质数。 所以可以在函数一开始就排除偶数,然后循环的时候每次递增2。

function isPrimeOptimized(int $number): bool {
  if ($number <= 1) {
    return false;
  }
  if ($number <= 3) {
    return true;
  }
  if ($number % 2 === 0 || $number % 3 === 0) {
    return false;
  }

  for ($i = 5; $i * $i <= $number; $i = $i + 6) {
    if ($number % $i === 0 || $number % ($i + 2) === 0) {
      return false;
    }
  }
  return true;
}

这个优化后的版本,先排除了小于等于1的数,然后直接处理了2和3这两个特殊的质数。 接着,排除了所有能被2或3整除的数。 最后,循环只检查那些不太容易被小质数整除的数,步长为6。 为什么是6呢? 因为所有质数(大于3的)都可以表示成

6k ± 1
的形式。 这可以进一步减少计算量。

PHP质数判断:如何处理大数?

CodeSquire
CodeSquire

AI代码编写助手,把你的想法变成代码

下载

处理大数时,简单的循环判断可能效率非常低。 比如要判断一个15位的数字是不是质数,用前面的方法可能需要几秒甚至几分钟。 这时候,可以考虑使用一些更高级的算法,比如 Miller-Rabin 质数测试。

Miller-Rabin 是一种概率性算法,它不能保证100%准确,但可以通过多次测试来提高准确率。 它的基本思想是基于费马小定理和二次探测定理。

function millerRabin(int $n, int $k = 5): bool {
    if ($n <= 1) return false;
    if ($n <= 3) return true;

    // 找到 (s, r) 使得 n - 1 = 2^s * r (r is odd)
    $s = 0;
    $r = $n - 1;
    while ($r % 2 == 0) {
        $s++;
        $r /= 2;
    }

    // 进行 k 次测试
    for ($i = 0; $i < $k; $i++) {
        $a = rand(2, $n - 2);
        $x = bcpowmod($a, $r, $n); // 使用 bcmath 扩展处理大数

        if ($x == 1 || $x == $n - 1) continue;

        for ($j = 0; $j < $s - 1; $j++) {
            $x = bcpowmod($x, 2, $n);
            if ($x == $n - 1) continue 2; // 继续外层循环
        }

        return false; // 不是质数
    }

    return true; // 有很大概率是质数
}

注意,这个函数使用了

bcmath
扩展来处理大数运算,因为 PHP 的标准整数类型可能无法存储非常大的数字。
bcpowmod
函数就是
bcmath
扩展提供的,用于计算大数的幂模运算。
$k
参数控制测试的次数,增加测试次数可以提高准确率,但也会增加计算时间。

PHP质数判断:与数组结合的应用场景

假设你需要生成一个包含前 N 个质数的数组。 你可以结合

isPrime
函数来完成这个任务。

function generatePrimeArray(int $n): array {
  $primes = [];
  $number = 2;
  while (count($primes) < $n) {
    if (isPrime($number)) {
      $primes[] = $number;
    }
    $number++;
  }
  return $primes;
}

// 示例
$primeArray = generatePrimeArray(10);
print_r($primeArray);

这个函数会从2开始,依次判断每个数字是否为质数,如果是,就添加到数组中,直到数组包含 N 个质数为止。 这在一些需要预先生成质数列表的场景下非常有用,比如密码学或者数论相关的应用。 当然,如果 N 很大,你可能需要考虑使用更高效的质数生成算法。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2032

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1364

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1274

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

949

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1405

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1231

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1440

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 10.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

NumPy 教程
NumPy 教程

共44课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号