我是编码的新手,并且已经给出了这个我似乎无法做到的问题:
E.g. [4,3,2] => [24,6,2]
数字的阶乘是该数字与其下方所有整数的乘积.
E.g. the factorial of 4 is 4 * 3 * 2 * 1 = 24
如果该数字小于0,则拒绝它.
我创建的代码是这样的;
function getFactorials(nums) { if (nums === 0 || nums === 1) return 1; for (var i = nums - 1; i >= 1; i--) { nums *= i; } return nums; }
代码正在针对此测试运行;
describe("getFactorials",() => { it("returns [] when passed []",() => { expect(getFactorials([])).to.eql([]); }); it("returns one factorial",() => { expect(getFactorials([3])).to.eql([6]); }); it("returns multiple factorials",() => { expect(getFactorials([3,4,5])).to.eql([6,24,120]); }); it("returns largest factorials",8,9,10])).to.eql([6,40320,362880,3628800]); }); });
我该怎么做?
解决方法
首先,创建一个递归函数来计算单个数的阶乘:
function factorial(num) { if (num == 0 || num == 1) { return 1; } return num * factorial(num - 1); }
然后为数组做,只需像这样使用Array.prototype.map()
:
function getFactorials(arr) { var result = arr.map(x => factorial(x); return result; }
这是一个演示:
function factorial(num) { if (num == 0 || num == 1) { return 1; } return num * factorial(num - 1); } function getFactorials(arr) { var result = arr.map(x => factorial(x)); return result; } console.log(getFactorials([4,10])); console.log(getFactorials([])); console.log(getFactorials([1,2,5]));
希望这有帮助!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。