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


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

参考文章

相关推荐
Tisfy2 分钟前
LeetCode 3637.三段式数组 I:一次遍历(三种实现)
算法·leetcode·题解·模拟·数组·遍历·moines
笃行客从不躺平3 分钟前
Token 复习
java·分布式·spring cloud
菩提树下的凡夫4 分钟前
Python 环境管理工具
开发语言·python
遨游xyz9 分钟前
数据结构-哈希表
算法·哈希算法
索荣荣20 分钟前
JavaToken实战指南:从原理到应用
开发语言·python
Albert Edison21 分钟前
【Python】函数
java·linux·python·pip
zho_uzhou25 分钟前
c++ imgui implot绘图使用示例 visual studio
开发语言·c++·visual studio
dyyx11127 分钟前
C++中的过滤器模式
开发语言·c++·算法
2301_8187320639 分钟前
项目启动报错,错误指向xml 已解决
xml·java·数据库·后端·springboot
星夜泊客41 分钟前
C# 基础:为什么类可以在静态方法中创建自己的实例?
开发语言·经验分享·笔记·unity·c#·游戏引擎