素数筛:埃氏筛法 Java版本

文章目录

素数筛:埃氏筛法 Java版本

一、引言

素数是数学中的基础概念,它们是只有1和自身两个正因数的自然数。在计算机科学中,素数的筛选和生成有着广泛的应用,例如在密码学、算法设计等领域。埃拉托斯特尼筛法(Sieve of Eratosthenes)是一种古老而有效的算法,用于找出小于或等于给定数n的所有素数。本文将介绍埃氏筛法的基本原理,并展示如何用Java语言实现这一算法。

二、埃氏筛法原理

1、算法描述

埃氏筛法的基本思想是:从最小的素数2开始,逐步筛选掉2的倍数,然后是下一个未被筛选的最小素数的倍数,依此类推。通过这种方式,可以快速地筛选出一定范围内的所有素数。

2、算法步骤

  1. 创建一个布尔数组,用于标记数字是否为素数。初始时,除了0和1之外,所有数字都被认为是素数。
  2. 从2开始,标记2的倍数为非素数。
  3. 找到下一个未被标记的最小数字,标记其所有倍数为非素数。
  4. 重复步骤3,直到所有小于或等于n的数字都被检查过。

三、Java实现

1、基本实现

java 复制代码
import java.util.Scanner;

public class SieveOfEratosthenes {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        boolean[] isPrime = new boolean[n + 1];
        for (int i = 2; i <= n; i++) {
            isPrime[i] = true;
        }
        for (int p = 2; p <= n; p++) {
            if (isPrime[p]) {
                for (int i = p * p; i <= n; i += p) {
                    isPrime[i] = false;
                }
            }
        }
        for (int i = 2; i <= n; i++) {
            if (isPrime[i]) {
                System.out.println(i);
            }
        }
    }
}

2、优化实现

为了提高效率,可以只遍历到sqrt(n),因为大于sqrt(n)的素数倍数已经被小于sqrt(n)的素数倍数覆盖。

java 复制代码
import java.util.Scanner;

public class SieveOfEratosthenes {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        boolean[] isPrime = new boolean[n + 1];
        for (int i = 2; i <= n; i++) {
            isPrime[i] = true;
        }
        for (int p = 2; p * p <= n; p++) {
            if (isPrime[p]) {
                for (int i = p * p; i <= n; i += p) {
                    isPrime[i] = false;
                }
            }
        }
        for (int i = 2; i <= n; i++) {
            if (isPrime[i]) {
                System.out.println(i);
            }
        }
    }
}

四、总结

埃氏筛法是一种简单而高效的算法,适用于快速筛选出一定范围内的所有素数。通过Java语言的实现,我们可以轻松地应用这一算法来解决实际问题。本文提供了基本的实现方法和优化策略,帮助读者更好地理解和运用埃氏筛法。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

相关推荐
徐*红几秒前
java 线程池
java·开发语言
尚学教辅学习资料几秒前
基于SSM的养老院管理系统+LW示例参考
java·开发语言·java毕设·养老院
2401_85763639几秒前
计算机课程管理平台:Spring Boot与工程认证的结合
java·spring boot·后端
1 9 J2 分钟前
Java 上机实践4(类与对象)
java·开发语言·算法
Code apprenticeship3 分钟前
Java面试题(2)
java·开发语言
J不A秃V头A6 分钟前
Python爬虫:获取国家货币编码、货币名称
开发语言·爬虫·python
憨子周1 小时前
2M的带宽怎么怎么设置tcp滑动窗口以及连接池
java·网络·网络协议·tcp/ip
passer__jw7672 小时前
【LeetCode】【算法】3. 无重复字符的最长子串
算法·leetcode
passer__jw7672 小时前
【LeetCode】【算法】21. 合并两个有序链表
算法·leetcode·链表
sweetheart7-72 小时前
LeetCode22. 括号生成(2024冬季每日一题 2)
算法·深度优先·力扣·dfs·左右括号匹配