204. Count Primes
Last updated
Last updated
/**
* Time complexity :
* Space complexity :
*/
class Solution {
public int countPrimes(int n) {
if(n <= 2) return 0;
boolean[] isPrime = new boolean[n];
Arrays.fill(isPrime, true);
int count = n-2;
for(int i = 2; i*i < n; i++) {
if(!isPrime[i]) continue;
for(int j = i; i*j < n; j++) {
if(isPrime[i*j]) {
isPrime[i*j] = false;
count--;
}
}
}
return count;
}
}/**
* Time complexity :
* Space complexity :
*/
class Solution {
public int countPrimes(int n) {
if(n <= 2) return 0;
boolean[] isPrime = new boolean[n];
Arrays.fill(isPrime, true);
int count = n/2;
for(int i = 3; i*i < n; i += 2) {
if(!isPrime[i]) continue;
for(int j = i*i; j < n; j += i*2) {
if(isPrime[j]) {
isPrime[j] = false;
count--;
}
}
}
return count;
}
}