2021-06-15 00:49:18 -07:00
|
|
|
---
|
|
|
|
id: 598de241872ef8353c58a7a2
|
2022-02-16 22:48:09 +05:30
|
|
|
title: Valuta i coefficienti binomiali
|
2021-06-15 00:49:18 -07:00
|
|
|
challengeType: 5
|
|
|
|
forumTopicId: 302259
|
|
|
|
dashedName: evaluate-binomial-coefficients
|
|
|
|
---
|
|
|
|
|
|
|
|
# --description--
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
Scrivi una funzione per calcolare il coefficiente binomiale per il valore dato di n e k.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
Questa formula è consigliata:
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
$\\binom{n}{k} = \\frac{n!}{(n-k)!k!} = \\frac{n(n-1)(n-2)\\ldots(n-k+1)}{k(k-1)(k-2)\\ldots 1}$
|
|
|
|
|
|
|
|
# --hints--
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
`binom` dovrebbe essere una funzione.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert(typeof binom === 'function');
|
|
|
|
```
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
`binom(5,3)` dovrebbe restituire 10.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.equal(binom(5, 3), 10);
|
|
|
|
```
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
`binom(7,2)` dovrebbe restituire 21.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.equal(binom(7, 2), 21);
|
|
|
|
```
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
`binom(10,4)` dovrebbe restituire 210.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.equal(binom(10, 4), 210);
|
|
|
|
```
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
`binom(6,1)` dovrebbe restituire 6.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.equal(binom(6, 1), 6);
|
|
|
|
```
|
|
|
|
|
2022-02-16 22:48:09 +05:30
|
|
|
`binom(12,8)` dovrebbe restituire 495.
|
2021-06-15 00:49:18 -07:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.equal(binom(12, 8), 495);
|
|
|
|
```
|
|
|
|
|
|
|
|
# --seed--
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
```js
|
|
|
|
function binom(n, k) {
|
|
|
|
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
# --solutions--
|
|
|
|
|
|
|
|
```js
|
|
|
|
function binom(n, k) {
|
|
|
|
let coeff = 1;
|
|
|
|
for (let i = n - k + 1; i <= n; i++) coeff *= i;
|
|
|
|
for (let i = 1; i <= k; i++) coeff /= i;
|
|
|
|
return coeff;
|
|
|
|
}
|
|
|
|
```
|