LeetCode 204. 计数质数
204题目:
给定整数 n ,返回 所有小于非负整数 n 的质数的数量 。
示例 1:
输入:n = 10
输出:4
解释:小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。
示例 2:
输入:n = 0
输出:0
示例 3:
输入:n = 1
输出:0
提示:
0 <= n <= 5 * 106
普通枚举 题解1
数据量过大 超时
//判断是否为质数
static boolean isPrime(int i) {
boolean flag = true;
for (int j = 2; j <= Math.sqrt(i); j++) {
if (i % j == 0) {
flag = false;
break;
}
}
return flag;
}
//质数个数
public static int countPrimes(int n) {
int sum = 0;
for (int i = 2; i <= n; i++) {
if (isPrime(i)) {
sum++;
}
}
return sum;
}
厄拉多塞筛法筛法 可以去看下题解
主要理解其中的思想
public static int countPrimes(int n) {
boolean [] isPrime=new boolean [n];
Arrays.fill(isPrime, true);
int ans=0;
//从2开始枚举到n;
for (int i = 2; i <n; i++) {
//如果是素数
if (isPrime[i]) {
ans+=1;
if ((long) i * i < n) {// 还在n的区间内 i的倍数都设为false
for (int j = i*i; j <n; j+=i) {
isPrime[j]=false;
}
}
}
}
return ans;
}