---
id: 597b2b2a2702b44414742771
title: 階乗
challengeType: 5
forumTopicId: 302263
dashedName: factorial
---
# --description--
数字の階乗を返す関数を作成します。
数値の階乗は次のようになります。
n! = n * (n-1) * (n-2) * ..... * 1
例:
3! = 3 * 2 * 1 = 6
4! = 4 * 3 * 2 * 1 = 24
**注:** `0! = 1` です。
# --hints--
`factorial` という関数です。
```js
assert(typeof factorial === 'function');
```
`factorial(2)` は数字を返します。
```js
assert(typeof factorial(2) === 'number');
```
`factorial(3)` は6を返します。
```js
assert.equal(factorial(3), 6);
```
`factorial(5)` は120を返します。
```js
assert.equal(factorial(5), 120);
```
`factorial(10)` は3,628,800を返します。
```js
assert.equal(factorial(10), 3628800);
```
# --seed--
## --seed-contents--
```js
function factorial(n) {
}
```
# --solutions--
```js
function factorial(n) {
let sum = 1;
while (n > 1) {
sum *= n;
n--;
}
return sum;
}
```