868. 筛质数 Java题解 (埃氏筛,线性筛)

编程入门 行业动态 更新时间:2024-10-23 23:34:42

868. 筛<a href=https://www.elefans.com/category/jswz/34/1764968.html style=质数 Java题解 (埃氏筛,线性筛)"/>

868. 筛质数 Java题解 (埃氏筛,线性筛)

输入样例:

8

输出样例:

4

解题思路:

埃氏筛质数:又叫朴素筛法,求某个区间的质数个数时,从2开始,将每个数的倍数都筛掉,剩下的数就是质数。缺点:会对某个数重复筛。时间复杂度为O(nlogn)

线性筛法:对埃氏筛的优化,埃氏筛的任意一个数都被它的因数筛了一遍,实际上只需要筛一次就行,即每次只用最小质因子筛,不会被重复筛,时间复杂度为O(nloglogn),非常接近线性。

两种筛法的相同点:都可以在筛选时找到质数的个数,求出区间内的所有质数,并且能求出每个数的最小质因子。

不同点:在10^6内,效率都差不多,但10^7时,线性筛明显比埃氏筛快一倍。

Java代码:(埃氏筛)

import java.io.*;public class Main {public static void main(String[] args) throws NumberFormatException, IOException {BufferedReader br = new BufferedReader(new InputStreamReader(System.in));int n = Integer.parseInt(br.readLine());getPrime(n);}public static void getPrime(int n) {boolean []st = new boolean[n + 1];  // 状态数组,标识是否被筛掉int []primes = new int[n + 1];  // 存放质数int cnt = 0;  //质数的个数for(int i = 2; i <= n; i++) { // 埃氏筛if(!st[i]) primes[cnt++] = i;for(int j = i + i; j <= n; j += i) // 将每个数的倍数都过滤掉,标志为truest[j] = true;}System.out.println(cnt);}
}

Java代码: (线性筛)

import java.io.*public class Main {public static void main(String[] args) throws NumberFormatException, IOException {BufferedReader br = new BufferedReader(new InputStreamReader(System.in));int n = Integer.parseInt(br.readLine());getPrime(n);}public static void getPrime(int n) {boolean []st = new boolean[n + 1];  // 状态数组,标识是否被筛掉int []primes = new int[n + 1];  // 存放质数int cnt = 0;  //质数的个数for(int i = 2; i <= n; i++) {  // 线性筛if(!st[i]) primes[cnt++] = i;for(int j = 0; primes[j] <= n / i; j++) {  //只用最小质因子筛,(筛一次)st[primes[j] * i] = true;if(i % primes[j] == 0) break;}}System.out.println(cnt);}
}

更多推荐

868. 筛质数 Java题解 (埃氏筛,线性筛)

本文发布于:2024-02-11 17:12:46,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1682194.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:质数   题解   线性   埃氏筛   Java

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!