freeCodeCamp/curriculum/challenges/japanese/10-coding-interview-prep/rosetta-code/factorial.md

81 lines
1.1 KiB
Markdown

---
id: 597b2b2a2702b44414742771
title: 階乗
challengeType: 5
forumTopicId: 302263
dashedName: factorial
---
# --description--
数字の階乗を返す関数を作成します。
数値の階乗は次のようになります。
<pre><big>n! = n * (n-1) * (n-2) * ..... * 1</big>
</pre>
例:
<ul>
<li><code>3! = 3 * 2 * 1 = 6</code></li>
<li><code>4! = 4 * 3 * 2 * 1 = 24</code></li>
</ul>
**注:** `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;
}
```