R
E
A
C
T
O
xamples
epeat
ode
pproach
ptimize
est
{ Sieve of Eratosthenes }
The Question
Write a program that uses the Sieve of Eratosthenes to find the sum of all the primes from 2 up to a given number
The Sieve of Eratosthenes is a simple, ancient algorithm for finding all prime numbers up to any given limit. It does so by iteratively marking as composite (i.e. not prime) the multiples of each prime, starting with the multiples of 2.
Create your range, starting at two and continuing up to and including the given limit. (i.e. [2, limit])
The algorithm consists of repeating the following over and over:
- take the next available unmarked number in your list (it is prime)
- mark all the multiples of that number (they are not prime)
Repeat until you have processed each number in your range.
When the algorithm terminates, all the numbers in the list that have not been marked are prime.
Huh?
Write a program that uses the Sieve of Eratosthenes to find the sum of all the primes from 2 up to a given number
Step 1
Create a Range of Potential Primes
function Erat(max){
var primes = [];
for (i=0; i< max; i++){
primes.push(true)
}
}
// Erat(5) --> [true,true,true,true,true]
Step 2
For each index in the array,
if you encounter a prime number at that index (a true)
then find all of it's multiples and mark them as not prime.
function Erat(max){
//step 1 stuff:
var primes = []
for (i=0; i< max; i++){
primes.push(true)
}
//step 2 stuff:
for(var x=2; x<primes.length; x++){
var multiple = x;
while(multiple < max){
multiple += x;
if(primes[multiple-1]){
primes[multiple-1] = false
}
}
}
//Erat(5) --> primes = [true, true, true, false, true]
}
Step 3
var sum = 0
primes.forEach(function(prime, idx, array){
if(idx==1){
sum -= 1
}
if(prime){
sum += idx+1
}
})
return sum
add it up
The Whole Kit-And-Kaboodle
function Erat(max){
//Step 1
var primes = []
for (i=0; i< max; i++){
primes.push(true)
}
//Step 2
for(var x=2; x<primes.length; x++){
var multiple = x
while(multiple < max){
multiple += x
if(primes[multiple-1]){
primes[multiple-1] = false
}
}
}
//Step 3
var sum = 0
primes.forEach(function(prime, idx, array){
if(idx==1){
sum -= 1
}
if(prime){
sum += idx+1
}
})
return sum
}
Conclusion
Solution on Repl.it
Source from Project Euler
Sieve of Eratosthenes
By Sarah Muenzinger
Sieve of Eratosthenes
Technical interview problem on the Sieve of Eratosthenes
- 1,741