Я попытался определить генератор с фиксированной точкой в C #, который вы видите во многих функциональных языках. Я полагаю, что foldr обычно определяется в терминах генератора с фиксированной точкой. Я покажу это определение Хаскеля, а затем то, что у меня есть в C #. Любая помощь с благодарностью.
//Haskell
fix f = f (fix f)
//C# (Many attempts)
public static Func<Func<T, T>, T> Combinator1<T>(this Func<T, T> f)
{
return x => f(Combinator1(f)(x));
}
public static Func<Func<T, T>, T> Combinator2<T>(this Func<T, T> f)
{
return x => x(Combinator2(x)(f));
}
public static Func<T, U> Combinator3<T, U>(Func<Func<T, U>, Func<T, U>> f)
{
return f(x => Combinator3(f)(x));
}