素数筛:埃氏筛法 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语言的实现,我们可以轻松地应用这一算法来解决实际问题。本文提供了基本的实现方法和优化策略,帮助读者更好地理解和运用埃氏筛法。


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

参考文章

相关推荐
lsx2024061 分钟前
Java 泛型
开发语言
wzf@robotics_notes1 分钟前
振动控制提升 3D 打印机器性能
嵌入式硬件·算法·机器人
jghhh0115 分钟前
基于MATLAB的可见光通信系统仿真实现
开发语言·matlab
机器学习之心20 分钟前
MATLAB基于多指标定量测定联合PCA、OPLS-DA、FA及熵权TOPSIS模型的等级预测
人工智能·算法·matlab·opls-da
茶本无香24 分钟前
@Scheduled(cron = “0 */5 * * * ?“) 详解
java·定时任务·scheduled
xiaoqider26 分钟前
C++模板进阶
开发语言·c++
yaonoran26 分钟前
【无标题】
java·开发语言·变量
Loo国昌29 分钟前
【LangChain1.0】第八阶段:文档处理工程(LangChain篇)
人工智能·后端·算法·语言模型·架构·langchain
康小庄32 分钟前
浅谈Java中的volatile关键字
java·开发语言·jvm·spring boot·spring·jetty
vx_bisheyuange34 分钟前
基于SpringBoot的海鲜市场系统
java·spring boot·后端·毕业设计