Digit factorials: Find the Sum of All the Curious Numbers
- 时间:2020-09-10 12:45:51
- 分类:网络文摘
- 阅读:126 次
145 is a curious number, as 1! + 4! + 5! = 1 + 24 + 120 = 145.
Find the sum of all numbers which are equal to the sum of the factorial of their digits.
Note: as 1! = 1 and 2! = 2 are not sums they are not included.
Pre-computing the Digit factorials
The factorials we all need to know are from 0! to 9!. Therefore, we can pre-compute the digital factorials and store them in a dictionary (or hash map).
1 2 3 4 5 6 7 | let factorials = {}; let s = 1; for (let i = 1; i <= 9; ++ i) { s *= i; factorials[i] = s; } factorials[0] = 1; |
let factorials = {};
let s = 1;
for (let i = 1; i <= 9; ++ i) {
s *= i;
factorials[i] = s;
}
factorials[0] = 1;A single loop from 1 to 9 is sufficient as we are iteratively multiple the next number.
Uppper bound of the Curious Numbers
We don’t need to and we can’t search infinite numbers. One upperbound we can use is 9999999 as 7*9! is less than 9999999.
We then bruteforce all the numbers and sum those curious numbers. The curious number can be determined by the following procedure: converted to string, and split into char array, then sum up the digital factorials, finally comparing the sum with the number.
1 2 3 4 5 6 7 8 9 10 | let sum = 0; for (let i = 3; i <= 9999999; ++ i) { let x = String(i).split('').reduce((a, b) => { return a + factorials[b]; }, 0); if (x === i) { sum += i; } } console.log(sum); |
let sum = 0;
for (let i = 3; i <= 9999999; ++ i) {
let x = String(i).split('').reduce((a, b) => {
return a + factorials[b];
}, 0);
if (x === i) {
sum += i;
}
}
console.log(sum);The answer is 40730.
–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:冬季适当吃糯米类食物有御寒滋补之功效 三类护耳食物可以延缓老年人听力下降 红枣养生知识:食用红枣需注意的问题 健康面点拒绝这些有毒的添加剂原料 火锅健康吃法:先素后荤 煮烫适度 少吃辣 柚子的保健功效以及食用柚子的禁忌 许多人已经走入了补充益生菌的误区 怎么吃核桃对男人的补肾效果最好 人体感冒时候应避免食用这些食物 感冒时多吃这些食物有助于感冒治愈
- 评论列表
-
- 添加评论