package com.example.sieve;
import java.util.BitSet;
/**
* 埃拉托色尼筛选法
* 测试编译器性能的一种流行的基准
* 思路:素数的倍数不是素数,可以先把素数的倍数排除掉,剩下的就是素数
*/
public class Sieve {
public static void main(String[] args) {
int n = 2000000;
long start = System.currentTimeMillis();
var bitSet = new BitSet(n + 1);
int count = 0;
int i;
for(i = 2; i <= n; i++){
bitSet.set(i);
}
i = 2;
while(i * i <= n){
if(bitSet.get(i)){
count++;
// i 的倍数肯定不是素数
int k = 2 * i;
while(k <= n){
bitSet.clear(k);
k += i;
}
}
i++;
}
while(i <= n){
if(bitSet.get(i)){
count++;
}
i++;
}
long end = System.currentTimeMillis();
System.out.println(count + " primes");
System.out.println((end - start) + " milliseconds");
}
}