feat(euler): 17 - Number letter counts
-
This commit is contained in:
parent
b46c2aace0
commit
e6a6167a32
2 changed files with 83 additions and 1 deletions
|
@ -28,7 +28,7 @@ The source code can be found in the [src](src) directory. My thoughts about some
|
||||||
- [x] [15 - Lattice paths](src/15%20-%20Lattice%20paths.ts)
|
- [x] [15 - Lattice paths](src/15%20-%20Lattice%20paths.ts)
|
||||||
- [Thoughts](thoughts/15%20-%20Lattice%20paths.md)
|
- [Thoughts](thoughts/15%20-%20Lattice%20paths.md)
|
||||||
- [x] [16 - Power digit sum](src/16%20-%20Power%20digit%20sum.ts)
|
- [x] [16 - Power digit sum](src/16%20-%20Power%20digit%20sum.ts)
|
||||||
- [ ] 17 - Number letter counts
|
- [x] [17 - Number letter counts](src/17%20-%20Number%20letter%20counts.ts)
|
||||||
- [ ] 18 - Maximum path sum I
|
- [ ] 18 - Maximum path sum I
|
||||||
- [ ] 19 - Counting Sundays
|
- [ ] 19 - Counting Sundays
|
||||||
- [ ] 20 - Factorial digit sum
|
- [ ] 20 - Factorial digit sum
|
||||||
|
|
82
challenges/euler/src/17 - Number letter counts.ts
Normal file
82
challenges/euler/src/17 - Number letter counts.ts
Normal file
|
@ -0,0 +1,82 @@
|
||||||
|
export {};
|
||||||
|
|
||||||
|
const translations = {
|
||||||
|
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'
|
||||||
|
};
|
||||||
|
|
||||||
|
// works for what we need, could be improved
|
||||||
|
const numberToWords = (n: number): string => {
|
||||||
|
let out = '';
|
||||||
|
|
||||||
|
// Deal with thousands
|
||||||
|
const thousands = Math.floor(n / 1000);
|
||||||
|
|
||||||
|
if (thousands > 0) {
|
||||||
|
for (let i = 0; i < thousands; i++) n -= 1000;
|
||||||
|
out += `${translations[thousands]} thousand`;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deal with hundreds
|
||||||
|
const hundreds = Math.floor(n / 100);
|
||||||
|
|
||||||
|
if (hundreds > 0) {
|
||||||
|
for (let i = 0; i < hundreds; i++) n -= 100;
|
||||||
|
out += `${translations[hundreds]} hundred`;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deal with tens
|
||||||
|
const tens = Math.floor(n / 10);
|
||||||
|
|
||||||
|
if (tens > 0) {
|
||||||
|
if (hundreds > 0) out += ' and ';
|
||||||
|
for (let i = 0; i < tens; i++) n -= 10;
|
||||||
|
|
||||||
|
if (n % 10 > 0 && tens == 1) {
|
||||||
|
out += `${translations[10 + (n % 10)]}`;
|
||||||
|
n -= n % 10;
|
||||||
|
} else out += `${translations[tens * 10]} `;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deal with the remainder
|
||||||
|
if (n > 0) {
|
||||||
|
if (hundreds > 0 && tens <= 0) out += ' and ';
|
||||||
|
out += translations[n];
|
||||||
|
}
|
||||||
|
|
||||||
|
return out;
|
||||||
|
};
|
||||||
|
|
||||||
|
let sum = 0;
|
||||||
|
|
||||||
|
for (let i = 1; i <= 1000; i++) {
|
||||||
|
// Strip the words of all whitespace and add the length to the sum
|
||||||
|
sum += numberToWords(i).replace(/\s+/g, '').length;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(sum);
|
Loading…
Reference in a new issue