如何解决超长阶乘挑战给我不同的 JavaScript 结果
我认为这段代码有效,但在挑战中他们要求我返回 “15511210043330985984000000”而不是“1.5511210043330984e+25”我不明白可能是什么问题。我试过将“BigInt”放在我的结果之前,但这给了我类似“15511210043330985984000000n”这个“n”在每个数字的末尾。
function extraLongFactorials(n) {
let result = 1;
for(let i = n; i >= 1; i--) {
result *= i;
}
return result;
}
console.log(extraLongFactorials(25));
// should be 15511210043330985984000000
解决方法
使用 BigInt() 后跟 toString()
BigInt(Number.MAX_VALUE).toString()
//'179769313486231570814527423731704356798070567525844996598917476803157260780028538760589558632766878171540458953514382464234321326889464182768467546703537516986049910576551282076245490090389328944075868508455133942304583236903222948165808559332123348274797826204144723168738177180919299881250404026184124858368'
,
好吧,我找到了这个解决方案。这与@undg 所说的非常接近,但与我期待的答案略有不同。
function extraLongFactorials(n) {
n = BigInt(n)
let result = BigInt(1);
for(let i = n; i >= 1; i--) {
result *= i;
}
return result.toString();
}
console.log(extraLongFactorials(25)); // 15511210043330985984000000
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。