微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 如何创建一个返回数组中每个整数的阶乘的函数

我是编码的新手,并且已经给出了这个我似乎无法做到的问题:

创建一个采用正整数数组的函数,并返回这些数字的阶乘数组.

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 举报,一经查实,本站将立刻删除。

相关推荐