forked from jyxia/LeetCode-JavaScript
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path204-countPrimes.js
53 lines (49 loc) · 1.3 KB
/
204-countPrimes.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/**
* @param {number} n
* @return {number}
*/
var countPrimes = function(n) {
var count = 0;
for (var i = 1; i < n; i++) {
if (isPrime(i)) count++;
}
return count;
};
// traditional approach, to determine a number is prime or not,
// only need to consider factors up to √n
var isPrime = function(num) {
if (num <= 1) return false;
// Loop's ending condition is i * i <= num instead of i <= sqrt(num)
// to avoid repeatedly calling an expensive function sqrt().
for (var i = 2; i * i <= num; i++) {
if (num % i == 0) return false;
}
return true;
};
/**
* A better solution using Sieve of Eratosthenes
* if the current number is p,
* mark off multiples of p starting at p^2, then in increments of p: p^2 + p, p^2 + 2p, ...
* these above numbers are not prime numbers
*
* @param {number} n
* @return {number}
*/
var countPrimes = function(n) {
var count = 0;
var isPrime = [];
for (var i = 2; i < n; i++) isPrime[i] = true;
for (var i = 2; i * i < n; i++) {
if (isPrime[i]) {
var start = i * i;
while (start <= n) {
isPrime[start] = false;
start = start + i;
}
}
}
for (var j = 2; j < n; j++) {
if (isPrime[j]) count++;
}
return count;
};