blob: 547d2d5f2521db1e06ec5508629c4e599c04df24 [file] [log] [blame]
// The Great Computer Language Shootout
// http://shootout.alioth.debian.org
//
// Contributed by Ian Osgood
function pad(n,width) {
var s = n.toString();
while (s.length < width) s = ' ' + s;
return s;
}
function primes(isPrime, n) {
var i, count = 0, m = 10000<<n, size = m+31>>5;
for (i=0; i<size; i++) isPrime[i] = 0xffffffff;
for (i=2; i<m; i++)
if (isPrime[i>>5] & 1<<(i&31)) {
for (var j=i+i; j<m; j+=i)
isPrime[j>>5] &= ~(1<<(j&31));
count++;
}
}
function sieve() {
for (var i = 4; i <= 11; i++) {
var isPrime = new Array((10000<<i)+31>>5);
primes(isPrime, i);
}
return isPrime;
}
var result = sieve();
var sum = 0;
for (var i = 0; i < result.length; ++i)
sum += result[i];
var expected = -116331605199501;
if (sum != expected)
throw "ERROR: bad result: expected " + expected + " but got " + sum;