init add
This commit is contained in:
commit
eea5337024
27
11.js
Normal file
27
11.js
Normal file
|
@ -0,0 +1,27 @@
|
|||
import * as std from "std";
|
||||
|
||||
var data = std.loadFile("11.txt").trim().split('n');
|
||||
for (var i = 0; i < data.length; i++) {
|
||||
data[i] = data[i].split(' ');
|
||||
data[i] = data[i].map(x=>Number(x));
|
||||
}
|
||||
|
||||
var high = 0;
|
||||
|
||||
data.forEach(function(line) {
|
||||
for (var i = 0; i < line.length-4; i++) {
|
||||
var n = line.slice(i,i+4).reduce((a,c) => a *= c);
|
||||
high = n > high ? n : high;
|
||||
}
|
||||
});
|
||||
|
||||
for (var i = 0; i < data[0].length-4; i++) {
|
||||
for (var j = 0; j < data[0].length; j++) {
|
||||
console.log(`${i},${j}`);
|
||||
var n = data[i][j]*data[i+1][j]*data[i+2][j]*data[i+3][j];
|
||||
console.log(`${i},${j}`);
|
||||
high = n > high ? n : high;
|
||||
}
|
||||
}
|
||||
|
||||
console.log(high);
|
20
11.txt
Normal file
20
11.txt
Normal file
|
@ -0,0 +1,20 @@
|
|||
08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
|
||||
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
|
||||
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
|
||||
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
|
||||
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
|
||||
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
|
||||
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
|
||||
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
|
||||
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
|
||||
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
|
||||
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
|
||||
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
|
||||
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
|
||||
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
|
||||
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
|
||||
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
|
||||
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
|
||||
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
|
||||
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
|
||||
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48
|
11
12.js
Normal file
11
12.js
Normal file
|
@ -0,0 +1,11 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var i = 1;
|
||||
var c = 0;
|
||||
while (true) {
|
||||
c += i++;
|
||||
if (euler.divisors(c).length > 500) {
|
||||
console.log(c);
|
||||
break;
|
||||
}
|
||||
}
|
25
14.js
Normal file
25
14.js
Normal file
|
@ -0,0 +1,25 @@
|
|||
var high_c = 1;
|
||||
var high = 1;
|
||||
|
||||
var collatz = function(n)
|
||||
{
|
||||
if (n%2===0)
|
||||
return n/2;
|
||||
return 3*n+1;
|
||||
}
|
||||
|
||||
for (var i = 2; i < 1000000; i++) {
|
||||
var c = 1;
|
||||
var n = i;
|
||||
while (n !== 1) {
|
||||
n = collatz(n);
|
||||
c++;
|
||||
}
|
||||
|
||||
if (c > high_c) {
|
||||
high_c = c;
|
||||
high = i;
|
||||
}
|
||||
}
|
||||
|
||||
console.log(high);
|
10
15.js
Normal file
10
15.js
Normal file
|
@ -0,0 +1,10 @@
|
|||
"use math";
|
||||
import * as euler from 'euler.js'
|
||||
|
||||
function lattice_moves(n)
|
||||
{
|
||||
return euler.factorial(n*2)/(euler.factorial(n)*euler.factorial(n));
|
||||
}
|
||||
|
||||
console.log(lattice_moves(20));
|
||||
|
7
16.js
Normal file
7
16.js
Normal file
|
@ -0,0 +1,7 @@
|
|||
"use math";
|
||||
var n = 1;
|
||||
for (var i = 0; i < 1000; i++)
|
||||
n *= 2;
|
||||
|
||||
var s = String(n).split('').map(x=>Number(x)).reduce((a,i)=>a+=i);
|
||||
console.log(s);
|
80
17.js
Normal file
80
17.js
Normal file
|
@ -0,0 +1,80 @@
|
|||
var numstrs = [];
|
||||
|
||||
var nstr = {
|
||||
0: '',
|
||||
1: 'one',
|
||||
2: 'two',
|
||||
3: 'three',
|
||||
4: 'four',
|
||||
5: 'five',
|
||||
6: 'six',
|
||||
7: 'seven',
|
||||
8: 'eight',
|
||||
9: 'nine',
|
||||
10: 'ten',
|
||||
11: 'eleven',
|
||||
12: 'twelve',
|
||||
13: 'thirteen',
|
||||
14: 'fourteen',
|
||||
15: 'fifteen',
|
||||
16: 'sixteen',
|
||||
17: 'seventeen',
|
||||
18: 'eighteen',
|
||||
19: 'nineteen',
|
||||
20: 'twenty',
|
||||
30: 'thirty',
|
||||
40: 'forty',
|
||||
50: 'fifty',
|
||||
60: 'sixty',
|
||||
70: 'seventy',
|
||||
80: 'eighty',
|
||||
90: 'ninety',
|
||||
100: 'hundred',
|
||||
1000: 'thousand'
|
||||
1000000: 'million',
|
||||
100000000: 'billion',
|
||||
100000000000: 'trillion',
|
||||
};
|
||||
|
||||
var tens2str = function(n) {
|
||||
if (n > 99) return "";
|
||||
|
||||
if (n <= 20) return nstr[n];
|
||||
var s = String(n).split('');
|
||||
return nstr[Number(s[0])*10] + '-' + nstr[s[1]];
|
||||
}
|
||||
|
||||
var num2str = function(n)
|
||||
{
|
||||
if (n === 0) return 'zero';
|
||||
|
||||
var s = String(n).split('');
|
||||
var tens = s.slice(s.length-2, s.length);
|
||||
var rest = s.slice(0, s.length-2).reverse();
|
||||
|
||||
rest = rest.map(function(v,i) {
|
||||
if (v === '0') return "";
|
||||
return nstr[v] + " " + nstr[Math.pow(10,i+2)] + " and ";
|
||||
});
|
||||
|
||||
rest = rest.reverse().filter(x=>x).join('');
|
||||
rest += tens2str(Number(tens.join('')));
|
||||
rest = rest.replace(/ and $/, '');
|
||||
rest = rest.replace(/-$/,'');
|
||||
return rest;
|
||||
}
|
||||
|
||||
var lettersinnum = function(n)
|
||||
{
|
||||
var str = num2str(n).replaceAll(/[- ]/g,'');
|
||||
return str.length;
|
||||
}
|
||||
|
||||
var sum = 0;
|
||||
for (var i = 1; i <= 1000; i++) {
|
||||
console.log(num2str(i));
|
||||
sum += lettersinnum(i);
|
||||
}
|
||||
|
||||
console.log(sum);
|
||||
|
8
20.js
Normal file
8
20.js
Normal file
|
@ -0,0 +1,8 @@
|
|||
"use math";
|
||||
var n = 1;
|
||||
for (var i = 100; i > 0; i--)
|
||||
n *= i;
|
||||
|
||||
console.log(n);
|
||||
var s = String(n).split('').map(x=>Number(x)).reduce((a,i)=>a+=i);
|
||||
console.log(s);
|
24
21.js
Normal file
24
21.js
Normal file
|
@ -0,0 +1,24 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var divsum = function(n) { return euler.divisors(n).reduce((y,i) => y += i); }
|
||||
|
||||
var amicable = function(a)
|
||||
{
|
||||
var b = divsum(a);
|
||||
if (divsum(b) === a) return b;
|
||||
return undefined;
|
||||
}
|
||||
|
||||
var ams = [];
|
||||
|
||||
for (var i = 1; i < 10000; i++) {
|
||||
var am = amicable(i);
|
||||
if (am && am !== i)
|
||||
ams.push(i, am);
|
||||
}
|
||||
|
||||
function unique(v,i,a) { return a.indexOf(v) === i; }
|
||||
|
||||
ams = ams.filter(unique);
|
||||
console.log(ams);
|
||||
console.log(ams.reduce((y,x) => y+=x));
|
15
22.js
Normal file
15
22.js
Normal file
|
@ -0,0 +1,15 @@
|
|||
import * as std from 'std';
|
||||
|
||||
var names = std.loadFile('22_names.txt').replaceAll(/"/g, '').split(',');
|
||||
names = names.sort();
|
||||
|
||||
var sum = 0;
|
||||
|
||||
names.forEach(function(n,i) {
|
||||
var score = 0;
|
||||
n = n.toUpperCase().split('').map(c => c.charCodeAt(0));
|
||||
n.forEach(c => score += (c-64));
|
||||
sum += (score*(i+1));
|
||||
});
|
||||
|
||||
console.log(sum);
|
1
22_names.txt
Normal file
1
22_names.txt
Normal file
File diff suppressed because one or more lines are too long
7
23.js
Normal file
7
23.js
Normal file
|
@ -0,0 +1,7 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var perfect_number = function(n)
|
||||
{
|
||||
var s = euler.divisors(n).reduce((a,n)=>a+=n);
|
||||
return n === s;
|
||||
}
|
17
24.js
Normal file
17
24.js
Normal file
|
@ -0,0 +1,17 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var nums = [0,1,2,3,4,5,6,7,8,9,];
|
||||
|
||||
var tar = 1000000;
|
||||
var a = "";
|
||||
for (var i = 0; i < 10; i++) {
|
||||
var f = euler.factorial(9-i);
|
||||
var n = Math.floor(tar/f);
|
||||
tar = tar%f;
|
||||
console.log(n);
|
||||
a += String(nums[n]);
|
||||
nums = nums.slice(0,n).concat(nums.slice(n+1));
|
||||
// console.log(nums);
|
||||
}
|
||||
|
||||
console.log(a);
|
28
25.js
Normal file
28
25.js
Normal file
|
@ -0,0 +1,28 @@
|
|||
var fibonacci = function(n)
|
||||
{
|
||||
if (fibonacci.cache[n]) return fibonacci.cache[n];
|
||||
|
||||
if (n < 2) return n;
|
||||
var f = 0l + fibonacci(n-1) + fibonacci(n-2);
|
||||
fibonacci.cache[n] = f;
|
||||
return f;
|
||||
}
|
||||
|
||||
fibonacci.cache = {};
|
||||
|
||||
var n = 1l;
|
||||
var s = fibonacci(n);
|
||||
|
||||
var digits = function(n)
|
||||
{
|
||||
var s = String(n.toExponential(0));
|
||||
s = s.match(/e.*/)[0].match(/\d+/)[0];
|
||||
return Number(s)+1;
|
||||
}
|
||||
|
||||
while (digits(s) < 1000) {
|
||||
n++;
|
||||
s = fibonacci(n);
|
||||
}
|
||||
|
||||
console.log(n);
|
111
26.js
Normal file
111
26.js
Normal file
|
@ -0,0 +1,111 @@
|
|||
"use math";
|
||||
|
||||
var longest_repeating = function(s)
|
||||
{
|
||||
var n = s.length;
|
||||
var LCSRe = new Array(n+1);
|
||||
for (var i = 0; i < n+1; i++) LCSRe[i] = new Array(n+1);
|
||||
for (var i = 0; i < n+1; i++)
|
||||
for (var j = 0; j < n+1; j++)
|
||||
LCSRe[i][j] = 0;
|
||||
|
||||
var res = "";
|
||||
var res_len = 0;
|
||||
var i = 0;
|
||||
var index = 0;
|
||||
|
||||
for (i = 1; i <= n; i++) {
|
||||
for (var j = i+1; j <= n; j++) {
|
||||
if (s[i-1] === s[j-1] && LCSRe[i-1][j-1] < (j-1)) {
|
||||
LCSRe[i][j] = LCSRe[i-1][j-1]+1;
|
||||
if (LCSRe[i][j] > res_len) {
|
||||
res_len = LCSRe[i][j];
|
||||
index = Math.max(i,index);
|
||||
}
|
||||
} else
|
||||
LCSRe[i][j] = 0;
|
||||
}
|
||||
}
|
||||
|
||||
if (res_len > 0)
|
||||
for (i = index-res_len+1; i <= index; i++)
|
||||
res += s.charAt(i-1);
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
var longest_hash = function(s)
|
||||
{
|
||||
var search = function(L, n, s) {
|
||||
var seen = {};
|
||||
var tmp;
|
||||
for (var start = 0; start < n-L+1; start++) {
|
||||
tmp = s.slice(start,start+L);
|
||||
if (seen[tmp]) return start;
|
||||
seen[tmp] = 1;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
var n = s.length;
|
||||
var l = 1;
|
||||
var r = n;
|
||||
var L;
|
||||
while (l<=r) {
|
||||
L = r;
|
||||
if (search(L,n,s) == -1)
|
||||
r = L-1;
|
||||
else
|
||||
l = L+1;
|
||||
}
|
||||
|
||||
return l-1;
|
||||
}
|
||||
|
||||
var high = 0;
|
||||
var high_len = 0;
|
||||
|
||||
var longest = function(s, min)
|
||||
{
|
||||
if (s.length === 1) return 1;
|
||||
var sa = [];
|
||||
for (var i = 0; i < s.length; i++)
|
||||
sa.push(s.slice(i));
|
||||
sa = sa.sort();
|
||||
var ll = 0;
|
||||
var lstr = "";
|
||||
for (var i = 0; i < s.length-1; i++) {
|
||||
var l = 0;
|
||||
while (sa[i][l] === sa[i+1][l])
|
||||
l++;
|
||||
|
||||
ll = Math.max(ll,l);
|
||||
lstr = sa[i].slice(0,l);
|
||||
}
|
||||
return lstr;
|
||||
}
|
||||
|
||||
var cycle = function(b)
|
||||
{
|
||||
var hash = {};
|
||||
var a = 1;
|
||||
var t = 0;
|
||||
do {
|
||||
hash[a] = t;
|
||||
a = a%b*10;
|
||||
t++;
|
||||
} while (hash[a] === undefined);
|
||||
return t-hash[a];
|
||||
}
|
||||
|
||||
var high = 0;
|
||||
var highlen = 0
|
||||
for (var i = 1; i < 1000; i++) {
|
||||
var len = cycle(i);
|
||||
if (len > highlen) {
|
||||
highlen = len;
|
||||
high = i;
|
||||
}
|
||||
}
|
||||
|
||||
console.log(high);
|
||||
|
35
27.js
Normal file
35
27.js
Normal file
|
@ -0,0 +1,35 @@
|
|||
import * as euler from 'euler.js';
|
||||
|
||||
function euler39(n) {
|
||||
if (n < 0 || n > 39) return undefined;
|
||||
return (n*n) + n + 41;
|
||||
}
|
||||
|
||||
function euler79(n) {
|
||||
if (n < 0 || n > 79) return undefined;
|
||||
return (n*n)-79*n+1601;
|
||||
}
|
||||
|
||||
function quadratic(a,b,c,x) {
|
||||
return x*x*a + x*b + c;
|
||||
}
|
||||
|
||||
var high = 0;
|
||||
var prod = 0;
|
||||
|
||||
for (var a = -999; a < 1000; a++) {
|
||||
for (var b = -1000; b <= 1000; b++) {
|
||||
var n = 0;
|
||||
var p = quadratic(1,a,b,n);
|
||||
while (euler.isprime(p)) {
|
||||
n++;
|
||||
p = quadratic(1,a,b,n);
|
||||
}
|
||||
if (n > high) {
|
||||
high = n;
|
||||
prod = a*b;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
console.log(prod);
|
13
29.js
Normal file
13
29.js
Normal file
|
@ -0,0 +1,13 @@
|
|||
var nums = [];
|
||||
|
||||
for (var a = 2; a <= 100; a++)
|
||||
for (var b = 2; b <= 100; b++)
|
||||
nums.push(Math.pow(a,b));
|
||||
|
||||
nums = nums.sort(function(a,b) {
|
||||
if (a > b) return 1;
|
||||
if (a < b) return -1;
|
||||
return 0;
|
||||
});
|
||||
nums = nums.filter((x,i) => nums.indexOf(x) === i);
|
||||
console.log(nums.length);
|
17
3.js
Normal file
17
3.js
Normal file
|
@ -0,0 +1,17 @@
|
|||
import * as euler from 'euler.js';
|
||||
|
||||
var tar = 600851475143;
|
||||
var star = Math.sqrt(tar);
|
||||
|
||||
var i = 0;
|
||||
var l = 0;
|
||||
|
||||
while (i < star)
|
||||
{
|
||||
if (euler.isprime(i) && tar%i === 0)
|
||||
l = i;
|
||||
|
||||
i++;
|
||||
}
|
||||
|
||||
console.log(l);
|
13
30.js
Normal file
13
30.js
Normal file
|
@ -0,0 +1,13 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var nums = [];
|
||||
|
||||
/* less than 9^5 * 6 */
|
||||
for (var i = 10; i < 354295; i++) {
|
||||
var d = euler.digitize(i);
|
||||
if (i === d.reduce((a,v) => a += v*v*v*v*v, 0))
|
||||
nums.push(i);
|
||||
}
|
||||
|
||||
console.log(nums);
|
||||
console.log(nums.reduce((a,v)=>a+=v));
|
30
32.js
Normal file
30
32.js
Normal file
|
@ -0,0 +1,30 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
function is_pandigital(n)
|
||||
{
|
||||
var s = String(n);
|
||||
var nums = s.split('').sort();
|
||||
return nums.every((x,i) => x == i+1);
|
||||
}
|
||||
|
||||
var prods = [];
|
||||
|
||||
a = 594;
|
||||
|
||||
for (var a = 1; a < 10000; a++)
|
||||
for (var b = 2; b < Math.sqrt(a)+1; b++) {
|
||||
var c = a*b;
|
||||
var digs = euler.digitize(a).concat(euler.digitize(b)).concat(euler.digitize(c)).sort();
|
||||
if (digs.length !== 9) continue;
|
||||
if (digs.every((x,i) => x == i+1)) prods.push(c);
|
||||
}
|
||||
|
||||
prods = prods.sort((a,b)=>a>=b?1:-1);
|
||||
|
||||
var sum = 0;
|
||||
for (var i = 0; i < prods.length; i++)
|
||||
sum += prods[i];
|
||||
|
||||
prods.forEach(p=>console.log(p));
|
||||
console.log(sum);
|
||||
|
12
34.js
Normal file
12
34.js
Normal file
|
@ -0,0 +1,12 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var nums = [];
|
||||
|
||||
console.log(145+40585);
|
||||
|
||||
for (var i = 0; i < 100000; i++) {
|
||||
var a = euler.digitize(i).reduce((a,v) => a += euler.factorial(v),0);
|
||||
if (a === i) nums.push(i);
|
||||
}
|
||||
|
||||
console.log(nums);
|
39
35.js
Normal file
39
35.js
Normal file
|
@ -0,0 +1,39 @@
|
|||
import * as euler from 'euler.js';
|
||||
|
||||
function rotate_num(n)
|
||||
{
|
||||
var digits = euler.digits(n);
|
||||
return Math.trunc((n%10)*Math.pow(10,digits-1)+(n/10));
|
||||
}
|
||||
|
||||
function num_rotated(n)
|
||||
{
|
||||
var rot = [n];
|
||||
var num = rotate_num(n);
|
||||
var digits = euler.digits(n);
|
||||
|
||||
while (num !== n && euler.digits(num) === digits) {
|
||||
rot.push(num);
|
||||
num = rotate_num(num);
|
||||
}
|
||||
return rot;
|
||||
}
|
||||
|
||||
function circular_prime(p)
|
||||
{
|
||||
var rot = num_rotated(p);
|
||||
return rot.every(n => primes[n]);
|
||||
}
|
||||
|
||||
var count = 0;
|
||||
var primes = {};
|
||||
|
||||
for (var i = 0; i < 1000000; i++)
|
||||
if (euler.isprime(i)) primes[i] = true;
|
||||
|
||||
Object.keys(primes).forEach(function(p) {
|
||||
p = Number(p);
|
||||
if (circular_prime(p)) count++;
|
||||
});
|
||||
|
||||
console.log(count);
|
30
36.js
Normal file
30
36.js
Normal file
|
@ -0,0 +1,30 @@
|
|||
function s_palindrome(s) { return s.split('').reverse().join('') === s; }
|
||||
|
||||
function n_reverse(n)
|
||||
{
|
||||
var rev = 0;
|
||||
while (n) {
|
||||
rev = 10*rev + n%10;
|
||||
n = n/10|0;
|
||||
}
|
||||
return rev;
|
||||
}
|
||||
|
||||
function is_palindrome(n)
|
||||
{
|
||||
var s = String(n);
|
||||
return s.split('').reverse().join('') === s;
|
||||
}
|
||||
|
||||
function db_palindrome(n)
|
||||
{
|
||||
var bs = n.toString(2);
|
||||
return n_reverse(n) === n && s_palindrome(bs);
|
||||
}
|
||||
|
||||
var sum = 0;
|
||||
|
||||
for (var i = 0; i < 1000000; i++)
|
||||
if (db_palindrome(i)) sum += i;
|
||||
|
||||
console.log(sum);
|
31
37.js
Normal file
31
37.js
Normal file
|
@ -0,0 +1,31 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
function trunc_l(n) {
|
||||
if (n < 10) return undefined;
|
||||
return Number(euler.digitize(n).slice(1).join(''));
|
||||
}
|
||||
|
||||
function trunc_r(n)
|
||||
{
|
||||
if (n < 10) return undefined;
|
||||
var s = euler.digitize(n);
|
||||
return Number(s.slice(0,s.length-1).join(''));
|
||||
}
|
||||
|
||||
var truncs = [];
|
||||
|
||||
outer: for (var i = 10; i < 1000000; i++) {
|
||||
if (euler.isprime(i)) {
|
||||
var r = i;
|
||||
while (r = trunc_r(r))
|
||||
if (!euler.isprime(r)) continue outer;
|
||||
var l = i;
|
||||
while (l = trunc_l(l))
|
||||
if (!euler.isprime(l)) continue outer;
|
||||
|
||||
truncs.push(i);
|
||||
}
|
||||
}
|
||||
|
||||
console.log(truncs);
|
||||
console.log(truncs.reduce((a,v) => a += v));
|
21
38.js
Normal file
21
38.js
Normal file
|
@ -0,0 +1,21 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var pans = [];
|
||||
outer:for (var i = 1; i < 10000; i++) {
|
||||
var digits = euler.digits(i);
|
||||
var c = "";
|
||||
for (var j = 1; j < Math.ceil(9/digits)+1; j++) {
|
||||
c += String(j*i);
|
||||
if (c.length > 9) continue outer;
|
||||
if (c.length === 9 && euler.is_pandigital(c)) {
|
||||
console.log(c);
|
||||
pans.push(Number(c));
|
||||
continue outer;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pans = pans.sort((a,b)=> a >=b ? 1 : -1);
|
||||
console.log(pans);
|
||||
console.log(pans[0]);
|
||||
console.log(pans[pans.length-1]);
|
11
4.js
Normal file
11
4.js
Normal file
|
@ -0,0 +1,11 @@
|
|||
var n1 = 999;
|
||||
var n2 = 999;
|
||||
var high = 0;
|
||||
var num_reverse = function(n) { return Number(String(n).split('').reverse().join('')); }
|
||||
|
||||
for (var n1 = 999; n1 >= 0; n1--)
|
||||
for (var n2 = 999; n2 > 0; n2--)
|
||||
if (num_reverse(n1*n2)===n1*n2)
|
||||
high = high > n1*n2 ? high : n1*n2;
|
||||
|
||||
console.log(high);
|
21
40.js
Normal file
21
40.js
Normal file
|
@ -0,0 +1,21 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var champernowne = function(n) {
|
||||
if (n < 0) return undefined;
|
||||
|
||||
n--;
|
||||
var c = 1;
|
||||
var d = euler.digits(c);
|
||||
while (n >= d) {
|
||||
n -= d;
|
||||
c++;
|
||||
d = euler.digits(c);
|
||||
}
|
||||
return euler.digitize(c)[n];
|
||||
}
|
||||
|
||||
var c = 1;
|
||||
for (var i = 1; i <= 1000000; i*=10)
|
||||
c *= champernowne(i);
|
||||
|
||||
console.log(c);
|
9
41.js
Normal file
9
41.js
Normal file
|
@ -0,0 +1,9 @@
|
|||
import * as euler from 'euler.js'
|
||||
|
||||
var pans = [];
|
||||
for (var i = 1; i < 10000000; i++) {
|
||||
if (!euler.isprime(i)) continue;
|
||||
if (euler.is_pandigital(i)) pans.push(i);
|
||||
}
|
||||
|
||||
console.log(pans[pans.length-1]);
|
21
46.js
Normal file
21
46.js
Normal file
|
@ -0,0 +1,21 @@
|
|||
import * as euler from './euler.js'
|
||||
var i = 0;
|
||||
|
||||
var primes = [];
|
||||
outer:for (var i = 2; i < 1000000; i++) {
|
||||
if (euler.isprime(i)) {
|
||||
primes.push(i);
|
||||
continue;
|
||||
}
|
||||
if (i%2 === 0) continue;
|
||||
|
||||
for (var p = 0; p < primes.length; p++) {
|
||||
var pr = primes[p];
|
||||
for (var j = 1; j < Math.sqrt(i); j++) {
|
||||
if (pr + (2*j*j) === i) continue outer;
|
||||
}
|
||||
}
|
||||
|
||||
console.log(i);
|
||||
break;
|
||||
}
|
11
48.js
Normal file
11
48.js
Normal file
|
@ -0,0 +1,11 @@
|
|||
"use math";
|
||||
|
||||
var sum = 0;
|
||||
for (var i = 1; i <= 1000; i++) {
|
||||
var s = i;
|
||||
for (var n = 1; n < i; n++)
|
||||
s *= i;
|
||||
sum += s;
|
||||
}
|
||||
|
||||
console.log(sum);
|
20
49.js
Normal file
20
49.js
Normal file
|
@ -0,0 +1,20 @@
|
|||
import * as euler from './euler.js'
|
||||
|
||||
function is_prime_perm(n)
|
||||
{
|
||||
if (!euler.isprime(n)) return false;
|
||||
var perms = euler.permutate_num(n);
|
||||
var c = 0;
|
||||
for (var j = 0; j < perms.length; j++)
|
||||
if (euler.isprime(perms[j])) c++;
|
||||
|
||||
if (c >= 3) return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
var p = [];
|
||||
outer:for (var i = 1000; i <= 9999; i++)
|
||||
if (is_prime_perm(i)) p.push(euler.permutate_num(i));
|
||||
|
||||
|
||||
p.forEach(z=>console.log(z));
|
7
9.js
Normal file
7
9.js
Normal file
|
@ -0,0 +1,7 @@
|
|||
outer: for (var c = 999; c > 3; c--)
|
||||
for (var b = c-1; b > 2; b--)
|
||||
for (var a = b-1; a > 1; a--)
|
||||
if (a*a+b*b===c*c && a+b+c === 1000) {
|
||||
console.log(a*b*c);
|
||||
break outer;
|
||||
}
|
122
euler.js
Normal file
122
euler.js
Normal file
|
@ -0,0 +1,122 @@
|
|||
export var isprime = function(num)
|
||||
{
|
||||
if (num == 2 || num == 3)
|
||||
return true;
|
||||
if (num <= 1 || num % 2 == 0 || num % 3 == 0)
|
||||
return false;
|
||||
for (let i = 5; i * i <= num ; i+=6) {
|
||||
if (num % i == 0 || num % (i + 2) == 0)
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
export function isodd(n) { return n%2; }
|
||||
export function iseven(n) { return !isodd(n); }
|
||||
|
||||
export var divisors = function(n)
|
||||
{
|
||||
var d = [];
|
||||
var high = Math.sqrt(n);
|
||||
for (var i = 2; i < high; i++)
|
||||
if (n%i === 0)
|
||||
d = d.concat([i, n/i]);
|
||||
|
||||
d.push(1);
|
||||
return d;
|
||||
}
|
||||
|
||||
export function rotate_num(n)
|
||||
{
|
||||
var dig = digits(n);
|
||||
return Math.trunc((n%10)*Math.pow(10,dig-1)+(n/10));
|
||||
}
|
||||
|
||||
function arr_swap(A,i,j)
|
||||
{
|
||||
var a = A[i];
|
||||
var b = A[j];
|
||||
A[i] = b;
|
||||
A[j] = a;
|
||||
}
|
||||
|
||||
|
||||
export function permutate_num(n)
|
||||
{
|
||||
var perms = [];
|
||||
function arr_gen(k, A)
|
||||
{
|
||||
if (k === 1) {
|
||||
perms.push(A.slice());
|
||||
return;
|
||||
}
|
||||
|
||||
arr_gen(k-1, A);
|
||||
|
||||
for (var i = 0; i < k-1; i++) {
|
||||
if (k%2 === 0)
|
||||
arr_swap(A,i,k-1);
|
||||
else
|
||||
arr_swap(A,0,k-1);
|
||||
|
||||
arr_gen(k-1,A);
|
||||
}
|
||||
}
|
||||
|
||||
var d = digitize(n);
|
||||
d = d.map(x=>String(x));
|
||||
arr_gen(d.length, d);
|
||||
perms = perms.map(function(p) {
|
||||
var n = "";
|
||||
for (var i = 0; i < p.length; i++)
|
||||
n += p[i];
|
||||
|
||||
return Number(n);
|
||||
});
|
||||
|
||||
return perms;
|
||||
}
|
||||
|
||||
export function is_pandigital(n)
|
||||
{
|
||||
var s = n;
|
||||
if (typeof s === 'number')
|
||||
s = String(s);
|
||||
var nums = s.split('').sort();
|
||||
return nums.every((x,i) => x == i+1);
|
||||
}
|
||||
|
||||
export var digitize = function(n)
|
||||
{
|
||||
var d = [];
|
||||
while (n) {
|
||||
d.push(n%10);
|
||||
n = Math.trunc(n/10);
|
||||
}
|
||||
return d.reverse();
|
||||
}
|
||||
|
||||
export var digits = function(n) { return Math.floor(Math.log10(Math.abs(n)))+1; }
|
||||
|
||||
export var factorial = function(n)
|
||||
{
|
||||
var s = 1;
|
||||
for (var i = n; i > 0; i--)
|
||||
s *= i;
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
export var combination = function(n,k) { return factorial(n)/(factorial(k)*factorial(n-k)); }
|
||||
|
||||
export var permutation = function(n,k) { return factorial(n)/factorial(n-k); }
|
||||
|
||||
export function euler39(n) {
|
||||
if (n < 0 || n > 39) return undefined;
|
||||
return (n*n) + n + 41;
|
||||
}
|
||||
|
||||
export function euler79(n) {
|
||||
if (n < 0 || n > 79) return undefined;
|
||||
return (n*n)-79*n+1601;
|
||||
}
|
Loading…
Reference in a new issue