私の脳は自虐モードにあるようで、これ、これ、およびこれに溺れた後、C#でDIYをいじりたいと思っていました。
私はYコンビネーターではないと思いますが、それ自体を参照せずに、非再帰関数を再帰的にすることができたようです:
Func<Func<dynamic, dynamic>, Func<dynamic, dynamic>> Y = x => x(x);
したがって、これらを考えると:
Func<dynamic, Func<dynamic, dynamic>> fact =
self => n => n == 0 ? 1 : n * self(self)(n - 1);
Func<dynamic, Func<dynamic, dynamic>> fib =
self => n => n < 2 ? n : self(self)(n-1) + self(self)(n-2);
これらを生成できます。
Func<dynamic, dynamic> Fact = Y(fact);
Func<dynamic, dynamic> Fib = Y(fib);
Enumerable.Range(0, 10)
.ToList()
.ForEach(i => Console.WriteLine("Fact({0})={1}", i, Fact(i)));
Enumerable.Range(0, 10)
.ToList()
.ForEach(i => Console.WriteLine("Fib({0})={1}", i, Fib(i)));