Быстро запоминайте анонимные рекурсивные функции с помощью лямбда-выражений и «функции исправления».C++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Быстро запоминайте анонимные рекурсивные функции с помощью лямбда-выражений и «функции исправления».

Сообщение Anonymous »

Справочная информация
Недавно я узнал, что комбинатор с фиксированной точкой позволяет легко определять рекурсивные функции, не называя их.
Он в основном используется в языках функционального программирования (например, функция fix), но вы можете имитировать ее внешний вид в C++20 следующим образом:

Код: Выделить всё

#include 

template 
struct Fix {
F f;
decltype(auto) operator()(auto arg) {
return f(std::ref(*this), arg);
}
};

int main() {
auto fact = Fix{[](auto self, int n) -> int {
return (n 

Подробнее здесь: [url]https://stackoverflow.com/questions/78213169/quickly-memoize-anonymous-recursive-functions-using-lambdas-and-the-fix-functio[/url]
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C++»