Java求质数常见几种方式

这篇具有很好参考价值的文章主要介绍了Java求质数常见几种方式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、循环遍历

public static boolean isPrime(int num) {
    if (num <= 1) {
        return false;
    }
    // 一定是 <= 号
    for (int i = 2; i <= Math.sqrt(num); i++) {
        if (num % i == 0) {
            return false;
        }
    }
    return true;
}

该方法的作用是判断一个整数是否是质数(即只能被1和自身整除的正整数)。方法接收一个整数参数num,返回一个布尔值,表示num是否为质数。

方法的实现原理是使用for循环从2到num的平方根(简单思考就可以想到不需要遍历到num-1)进行遍历,判断num是否能被这个数整除。如果能被整除,说明num不是一个质数,直接返回false。如果遍历完所有可能的因子都不能被整除,说明num是一个质数,返回true。

需要注意的是,该方法对于num小于等于1的情况直接返回false,因为1不是质数。

这种方法的时间复杂度为 O(n*sqrt(n)) ,在n的值很大的时候效率较低,如果需要找出大量质数,可以用更高效的算法,另外常见的两种方法为埃氏筛法和欧拉筛法

2、埃氏筛法(埃拉托斯特尼筛法)

埃氏筛法是一种简单又历史悠久的筛法。

埃氏筛法的基本思路是先把从2开始的所有数写下来,然后从2开始,将每个质数的倍数都标记成合数,即非质数,直到筛完所有小于等于给定数n的数。这样,留下的就是小于等于n的质数。

public static List<Integer> getPrimes(int n) {

    // 为了下标和n对应,数组长度为n + 1
    boolean[] isComposite = new boolean[n + 1]; // 标记数组,false表示该下标对应的数是质数
    List<Integer> primes = new ArrayList<>(); // 用动态数组ArrayList存储质数

    for (int i = 2; i <= n; i++) {
        if (!isComposite[i]) { // 如果该数是质数
            primes.add(i); // 把该数加入质数列表
            /* 常规思路是从 i * 2 开始,但是这样会重复判断多次
               从 i * i 开始遍历,可以略过很多次判断,因为只有
               从i的平方开始才不会和前面重复,略过了与前面数字
               的公倍数
               例如i = 2时,从4开始,判断 4 6 8 10 12 14...
               当i=3时,只需要从9开始判断3的倍数,而不需要判断
               2和3的公倍数6
            */
            for (int j = i * i; j <= n; j += i) { // 标记该数的倍数为合数
                isComposite[j] = true;
            }
        }
    }

    return primes;
}

埃氏筛法时间复杂度为O(nloglogn), 此算法会重复筛,如i=2时已经判断过12,但i=3时仍然需要再次判断,增加了时间复杂度,此算法依然有优化的空间

3、欧拉筛法

欧拉筛法的基本思路是将每个数表示为质数的乘积,然后按照质数的倍数依次筛选,这样每个合数只会被筛选一次,大大减少了时间复杂度

public static List<Integer> eulerSieve(int n) {
    
    boolean[] isPrime = new boolean[n + 1]; // 标记数组,false表示该下标对应的数是质数
    List<Integer> primes = new ArrayList<>(); // 用动态数组ArrayList存储质数
    for (int i = 2; i <= n; i++) {
        if (!isPrime[i]) { // 如果该数是质数
            primes.add(i); // 就放入数组中
        }
        // 循环质数的个数次 并且不能超出范围
        for (int j = 0; j < primes.size() && i * primes.get(j) <= n; j++) {
            // i的倍数一定是合数
            isPrime[i * primes.get(j)] = true;
            // 关键 当i能整除的时候就跳出循环
            if (i % primes.get(j) == 0) {
                break;
            }
        }
    }
    // primes列表中存储的就是所有小于等于n的质数
    return primes;
}

 欧拉筛法的时间复杂度是O(n),每一个合数都被它的最小质因数筛掉文章来源地址https://www.toymoban.com/news/detail-619010.html

到了这里,关于Java求质数常见几种方式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis 常见的几种数据结构说一下?各自的使用场景?

    介绍:string 数据结构是简单的 key-value 类型。 使用场景: 一般常用在需要计数的场景,比如用户的访问次数、热点文章的点赞转发数量等等。 介绍:list 即是 链表 使用场景:发布与订阅或者说消息队列、慢查询。 介绍:hash 类似于 JDK1.8 前的 HashMap,内部实现也差不多(数组

    2024年01月24日
    浏览(42)
  • Java中常见的几种HttpClient调用方式

    一、HttpURLConnection调用 方式一: 方式二: 缺点:不能直接使用池化技术,需要自行处理输入输出流 二、apache common封装HttpClient 引入依赖 实现 三、CloseableHttpClient 可以使用连接池保持连接,并且过期自动释放。引入jar包 引入依赖 实现 非连接池连接: 四、OkHttp3 引入依赖 实

    2024年02月04日
    浏览(55)
  • Java中String类的几种常见遍历方式

    今天小小的给自己总结一下String类的几种常见遍历方式,如下。 charAt(): charAt(int index) :返回 char指定索引处的值。 toCharArray() : toCharArray() :将此字符串转换为新的字符数组。 然后按照遍历字符串数组的方式遍历即可,可采用普通for循环遍历,也可以采用增强for循环遍历。 sub

    2024年02月16日
    浏览(42)
  • java实现调用http请求的几种常见方式

    ------ Oracle中文开发者社区 ------ 如果你想要学习编程,关注本博客,持续获得技术支持,持续获得技术咨询 java开发·企业官方账号 Oracle中国官方账号 Java中国管理部 全网粉丝30万+ 华为云享专家 阿里专家博主 CSDN内容合伙人 CSDN原力计划作者 51CTO专家博主 CSDN博客V账号 毕业于四川

    2024年02月04日
    浏览(53)
  • java中实现分页的常见几种方式

    无论是自我学习中,还是在工作中,固然会遇到 与前端搭配实现分页的功能 ,发现有几种方式,特此记录一下。 分页功能直接交给前端实现 (根据业务场景且仅仅只能用于 数据量少 的情况)。即后端不做任何数据的限制,直接把全部数据返回给前端,前端通过组件实现分页

    2023年04月10日
    浏览(36)
  • Java常见的数据结构:栈、队列、数组、链表、二叉树、二叉查找树、平衡二叉树、红黑树

    数据结构是计算机底层存储、组织数据的方式。是指数据相互之间是以什么方式排列在一起的。 通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率 栈 队列 数组 链表 二叉树 二叉查找树 平衡二叉树 红黑树... 后进先出,先进后出 数据进入栈模型的过程称为

    2024年02月07日
    浏览(38)
  • 数据结构|二叉树的三种遍历方式,你掌握了几种?

    目录 1、遍历方式 2、前序遍历 3、中序遍历 学习二叉树的结构,最简单的方式就是遍历二叉树。遍历二叉树就是 通过某条线路对二叉树的各个结点进行一次访问 ,访问的方法有三种分为前序遍历、中序遍历、后续遍历,层序遍历它们的遍历顺序如下所示: 前序遍历: 根节点

    2023年04月16日
    浏览(46)
  • 【一起学数据结构与算法】几种常见的排序(插入排序、选择排序、交换排序、归并排序)

    排序是计算机内经常进行的一种操作,其目的是将一组 “无序” 的记录序列调整为 “有序” 的记录序列。分 内部排序 和 外部排序 ,若整个排序过程不需要访问外存便能完成,则称此类排序问题为内部排序。反之,若参加排序的记录数量很大,整个序列的排序过程不可能

    2023年04月09日
    浏览(44)
  • Linux 下通过 java 命令启动 jar 包的几种常见方式

    Linux 下通过 java 命令启动 jar 包的几种常见方式 一、后台启动jar包命令 方法一:直接启动 jar 包服务 方法二:后台启动 jar 包服务 方法三:后台不挂断启动 方式四:指定日志输出的启动 方式五:指定配置文件启动 方式六:指定配置文件,使用系统默认的log配置,不另行指定

    2024年02月13日
    浏览(41)
  • 数据结构几种常见图的邻接矩阵的画法(有向图带权值,有向图不带权值,无向图带权值,无向图不带权值)

    这不马上要期末考试了,复习的时候突然发现了有好几种图的邻接矩阵需要画,在网上找了半天结果发现也没有特别详细的总结,所以经过总结写一下吧,希望对有需要的人,有点帮助吧!!!!(如有不对还请见谅!!!!!~~~~~~) 1,有向图带权值   2.有向图不带权值

    2024年02月13日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包