2022-01-08 18:44:43 +00:00
|
|
|
// The sum of the primes below 10 is 2 + 3 + 5 + 7 = 17.
|
|
|
|
// Find the sum of all the primes below two million.
|
2021-10-29 10:18:53 +00:00
|
|
|
export {};
|
|
|
|
|
2022-01-08 18:44:43 +00:00
|
|
|
/**
|
|
|
|
* Use the Sieve of Eratosthenes to find the sum of primes up until a limit.
|
|
|
|
* @see https://github.com/newtykins/the-honk/tree/main/projects/euler/thoughts/10%20-Summation%20of%29primes.md
|
|
|
|
*/
|
|
|
|
const sumOfPrimes = (limit: number) => {
|
2021-10-29 10:18:53 +00:00
|
|
|
let array: boolean[] = [];
|
2022-01-08 18:44:43 +00:00
|
|
|
let upperLimit = Math.sqrt(limit);
|
2021-10-29 10:18:53 +00:00
|
|
|
let output: number[] = [];
|
|
|
|
|
|
|
|
// Make an array from 2 to (n - 1) of truthy values
|
2022-01-08 18:44:43 +00:00
|
|
|
for (var i = 0; i < limit; i++) {
|
2021-10-29 10:18:53 +00:00
|
|
|
array.push(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove multiples of primes starting from 2, 3, 5,...
|
|
|
|
for (var i = 2; i <= upperLimit; i++) {
|
|
|
|
if (array[i]) {
|
2022-01-08 18:44:43 +00:00
|
|
|
for (var j = i * i; j < limit; j += i) {
|
2021-10-29 10:18:53 +00:00
|
|
|
array[j] = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// All array[i] set to true are primes
|
2022-01-08 18:44:43 +00:00
|
|
|
for (var i = 2; i < limit; i++) {
|
2021-10-29 10:18:53 +00:00
|
|
|
if (array[i]) {
|
|
|
|
output.push(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-08 18:44:43 +00:00
|
|
|
return output.reduce((a, b) => a + b);
|
2021-10-29 10:18:53 +00:00
|
|
|
};
|
|
|
|
|
2022-01-08 18:44:43 +00:00
|
|
|
// Output
|
2021-10-29 10:18:53 +00:00
|
|
|
console.log(sumOfPrimes(2000000));
|