Skip to content

Commit 9304858

Browse files
committed
y combinator for js
1 parent c6325b3 commit 9304858

File tree

1 file changed

+18
-0
lines changed

1 file changed

+18
-0
lines changed

src/little-schemer/y-combinator.js

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
function Y (g) {
2+
return (function (f) {
3+
return f(f);
4+
})(function (f) {
5+
return g(function () {
6+
return f(f).apply(null, arguments);
7+
});
8+
});
9+
};
10+
11+
12+
var fib = Y(function (fib_t) {
13+
return function (n) {
14+
if (n == 0) return 0;
15+
if (n == 1) return 1;
16+
return fib_t(n-1) + fib_t(n-2);
17+
};
18+
});

0 commit comments

Comments
 (0)