2.1 KiB
id, title, challengeType, forumTopicId, dashedName
| id | title | challengeType | forumTopicId | dashedName |
|---|---|---|---|---|
| 594810f028c0303b75339ad5 | Y комбінатор | 1 | 302345 | y-combinator |
--description--
In strict functional programming and the lambda calculus, functions (lambda expressions) don't have state and are only allowed to refer to arguments of enclosing functions. Це виключає звичайне визначення рекурсивної функції, коли функція асоціюється зі станом змінної, а стан цієї змінної використовується в основній частині функції.
The Y combinator is itself a stateless function that, when applied to another stateless function, returns a recursive version of the function. The Y combinator is the simplest of the class of such functions, called fixed-point combinators.
--instructions--
Define the stateless Y combinator function and use it to compute the factorials. The factorial(N) function is already given to you.
--hints--
Y повинен повернути функцію.
assert.equal(typeof Y((f) => (n) => n), 'function');
factorial(1) повинен повернути 1.
assert.equal(factorial(1), 1);
factorial(2) повинен повернути 2.
assert.equal(factorial(2), 2);
factorial(3) повинен повернути 6.
assert.equal(factorial(3), 6);
factorial(4) повинен повернути 24.
assert.equal(factorial(4), 24);
factorial(10) повинен повернути 3628800.
assert.equal(factorial(10), 3628800);
--seed--
--after-user-code--
var factorial = Y(f => n => (n > 1 ? n * f(n - 1) : 1));
--seed-contents--
function Y(f) {
return function() {
};
}
var factorial = Y(function(f) {
return function (n) {
return n > 1 ? n * f(n - 1) : 1;
};
});
--solutions--
var Y = f => (x => x(x))(y => f(x => y(y)(x)));