首页 > 后端开发 > C++ > 正文

c++ 素数判断代码 c++判断质数最高效算法

冰火之心
发布: 2025-12-16 17:33:06
原创
798人浏览过
该函数通过试除法优化判断质数:先处理小于等于3的数,排除能被2或3整除的数,再从5开始循环检查形如6k±1的数是否为因子,若存在则非质数,否则为质数。

c++ 素数判断代码 c++判断质数最高效算法

判断一个数是否为质数(素数)是编程中的常见问题。在 C++ 中,实现高效质数判断的关键在于减少不必要的计算。以下是一个高效且实用的素数判断函数,适用于大多数场景,包括大数判断。

基础原理:试除法优化

一个合数必定有一个小于等于其平方根的因子。因此只需检查从 2 到 √n 的整数即可。

进一步优化:

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

  • 先处理 2 和 3 的特殊情况
  • 之后只检查形如 6k±1 的数(因为所有大于 3 的质数都满足这个形式)
  • 跳过偶数和能被 3 整除的数

C++ 高效质数判断代码

以下是经过优化的判断函数:

#include <iostream>
#include <cmath>
<p>bool isPrime(int n) {
if (n <= 1) return false;
if (n <= 3) return true;
if (n % 2 == 0 || n % 3 == 0) return false;</p><pre class="brush:php;toolbar:false;">// 检查形如 6k ± 1 的因子
for (int i = 5; i * i <= n; i += 6) {
    if (n % i == 0 || n % (i + 2) == 0)
        return false;
}
return true;
登录后复制

}

Gaga
Gaga

曹越团队开发的AI视频生成工具

Gaga 1151
查看详情 Gaga

// 示例使用 int main() { int num; std::cout > num;

if (isPrime(num))
    std::cout << num << " 是质数。\n";
else
    std::cout << num << " 不是质数。\n";

return 0;
登录后复制

}

算法效率分析

该算法时间复杂度为 O(√n),但相比朴素试除法减少了约 2/3 的循环次数。原因如下:

  • 排除了所有偶数(除 2)
  • 排除了所有能被 3 整除的数(除 3)
  • 只测试可能为质数的形式:6k−1 和 6k+1

对于一般用途(如竞赛、工程),这种写法已经非常高效。

特殊情况说明

若需频繁判断多个数是否为质数,建议使用埃拉托斯特尼筛法预处理出一定范围内的所有质数,查询可达到 O(1) 时间。

基本上就这些。这个版本在速度与代码简洁之间取得了良好平衡,适合实际使用。

以上就是c++++ 素数判断代码 c++判断质数最高效算法的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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