我的大脑似乎处于自虐模式,所以在淹没在这个、这个和这个中之后,它想在 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)));