(euler) make puzzles functional

This commit is contained in:
newt 2024-10-09 18:02:35 +01:00
parent 6b17075cfa
commit 563866d555
7 changed files with 73 additions and 44 deletions

View file

@ -8,6 +8,7 @@
"devDependencies": { "devDependencies": {
"@types/node": "^16.11.6", "@types/node": "^16.11.6",
"chalk": "^4.1.2", "chalk": "^4.1.2",
"execution-time": "^1.4.1",
"gulp": "^4.0.2", "gulp": "^4.0.2",
"gulp-cli": "^2.3.0", "gulp-cli": "^2.3.0",
"gulp-rename": "^2.0.0", "gulp-rename": "^2.0.0",

View file

@ -1,6 +1,7 @@
const fs = require('fs'); const fs = require('fs');
const chalk = require('chalk'); const chalk = require('chalk');
const { spawnSync } = require('child_process'); const { spawnSync } = require('child_process');
const perf = require('execution-time')();
const run = (file, puzzleName) => { const run = (file, puzzleName) => {
// Calculate the length of the divider for the puzzle // Calculate the length of the divider for the puzzle
@ -10,12 +11,19 @@ const run = (file, puzzleName) => {
divider += '-'; divider += '-';
} }
// Log output // Styling
console.log(divider); console.log(divider);
console.log(chalk.bold(chalk.greenBright(puzzleName))); console.log(chalk.bold(chalk.greenBright(puzzleName)));
console.log(divider); console.log(divider);
// Execute the file
perf.start();
spawnSync('node', [`build/${file}`], { shell: true, stdio: 'inherit' }); spawnSync('node', [`build/${file}`], { shell: true, stdio: 'inherit' });
const results = perf.stop();
// Print time results
console.log();
console.log(chalk.bold(chalk.yellow(`Executed in ${results.words}`)));
}; };
// Get files // Get files

View file

@ -1,12 +1,13 @@
import { calcSum } from './utils'; import { calcSum } from './utils';
const below = 1000; const multiplesOf = (numbers: number[], upperBound: number) => {
const multiplesOf = [3, 5]; const results: Set<number> = new Set();
const toAdd: Set<number> = new Set();
// Find all of the multiples of 3 and 5 below 1000 for (let i = 1; i < upperBound; i++) {
for (let i = 1; i < below; i++) { numbers.forEach(num => (i % num == 0 ? results.add(i) : null));
multiplesOf.forEach(num => (i % num == 0 ? toAdd.add(i) : null));
} }
console.log(calcSum(Array.from(toAdd))); return Array.from(results);
};
console.log(calcSum(multiplesOf([3, 5], 1000)));

View file

@ -1,15 +1,22 @@
import { calcSum } from './utils'; import { calcSum } from './utils';
const fibonacciNumbers = (upperBound: number) => {
const sequence = [1, 2]; const sequence = [1, 2];
const max = 4000000;
// Keep making new nujm // Keep making new numbers in the sequence until we hit the upper bound
while (sequence[sequence.length - 1] < max) { while (sequence[sequence.length - 1] < upperBound) {
const newValue = sequence[sequence.length - 1] + sequence[sequence.length - 2]; const newValue = sequence[sequence.length - 1] + sequence[sequence.length - 2];
sequence.push(newValue); sequence.push(newValue);
} }
// Filter out the even numbers and find the sum return sequence;
};
const evenFibonacciNumbers = (upperBound: number) => {
const sequence = fibonacciNumbers(upperBound);
const even = sequence.filter(n => n % 2 === 0); const even = sequence.filter(n => n % 2 === 0);
console.log(calcSum(even));
return even;
};
console.log(calcSum(evenFibonacciNumbers(4000000)));

View file

@ -1,4 +1,4 @@
let number = 600851475143; const largestPrimeFactor = (number: number) => {
let i = 2; let i = 2;
while (i * i <= number) { while (i * i <= number) {
@ -6,4 +6,7 @@ while (i * i <= number) {
else number = Math.floor(number / i); else number = Math.floor(number / i);
} }
console.log(number); return number;
};
console.log(largestPrimeFactor(600851475143));

View file

@ -1,11 +1,9 @@
const biggest = 999; const largestPallidromeNumber = (lowerBound: number, upperBound: number) => {
const smallest = 100;
// Work out all of the products of 3 digit numbers // Work out all of the products of 3 digit numbers
const products: number[] = []; const products: number[] = [];
for (let i = smallest; i < biggest + 1; i++) { for (let i = lowerBound; i < upperBound + 1; i++) {
for (let j = smallest; j < biggest + 1; j++) { for (let j = lowerBound; j < upperBound + 1; j++) {
products.push(i * j); products.push(i * j);
} }
} }
@ -17,6 +15,7 @@ const palindromic = products.filter(
// Find the biggest palindrome number // Find the biggest palindrome number
const sorted = palindromic.sort((a, b) => b - a); const sorted = palindromic.sort((a, b) => b - a);
const largest = sorted[0]; return sorted[0];
};
console.log(largest); console.log(largestPallidromeNumber(100, 999));

View file

@ -926,6 +926,15 @@ __metadata:
languageName: node languageName: node
linkType: hard linkType: hard
"execution-time@npm:^1.4.1":
version: 1.4.1
resolution: "execution-time@npm:1.4.1"
dependencies:
pretty-hrtime: ^1.0.3
checksum: 0a5ef5604fc1ed9f626126443dfb52cd94926a657384433a3737e7878e1697e9b37e04e63a22e2ae2f6ac6bd20261f58fb8c890388f6d3fdf906425fca98be3d
languageName: node
linkType: hard
"expand-brackets@npm:^2.1.4": "expand-brackets@npm:^2.1.4":
version: 2.1.4 version: 2.1.4
resolution: "expand-brackets@npm:2.1.4" resolution: "expand-brackets@npm:2.1.4"
@ -2627,7 +2636,7 @@ __metadata:
languageName: node languageName: node
linkType: hard linkType: hard
"pretty-hrtime@npm:^1.0.0": "pretty-hrtime@npm:^1.0.0, pretty-hrtime@npm:^1.0.3":
version: 1.0.3 version: 1.0.3
resolution: "pretty-hrtime@npm:1.0.3" resolution: "pretty-hrtime@npm:1.0.3"
checksum: bae0e6832fe13c3de43d1a3d43df52bf6090499d74dc65a17f5552cb1a94f1f8019a23284ddf988c3c408a09678d743901e1d8f5b7a71bec31eeeac445bef371 checksum: bae0e6832fe13c3de43d1a3d43df52bf6090499d74dc65a17f5552cb1a94f1f8019a23284ddf988c3c408a09678d743901e1d8f5b7a71bec31eeeac445bef371
@ -2647,6 +2656,7 @@ __metadata:
dependencies: dependencies:
"@types/node": ^16.11.6 "@types/node": ^16.11.6
chalk: ^4.1.2 chalk: ^4.1.2
execution-time: ^1.4.1
gulp: ^4.0.2 gulp: ^4.0.2
gulp-cli: ^2.3.0 gulp-cli: ^2.3.0
gulp-rename: ^2.0.0 gulp-rename: ^2.0.0