169 похожих чатов

Type 'a logic = 'a logic_ Lazy and 'a

logic_ =
| Nil
| Cons of 'a * 'a logic

let inline apply
(yes : ('a * 'a logic) -> 'r)
(no : 'r)
(logic : 'a logic)
: 'r =
match logic.Value with
| Nil -> no
| Cons (x, xs) -> yes (x, xs)

let inline findAtLeast
(n : int)
(logic : 'a logic)
: 'a list =
List.unfold
(fun (n, logic) ->
if n <= 0
then None
else apply (fun (x, xs) -> Some (x, (n - 1, xs))) None logic)
(n, logic)

let rec unfold
(coalg : 'b -> ('a * 'b) option)
(seed : 'b)
: 'a logic =
match coalg seed with
| None -> lazy Nil
| Some (x, seed') -> lazy (Cons (x, unfold coalg seed'))

fairBind (unfold (fun x -> Some (x, x + 1)) 1) (fun x ->
just x)
|> findAtLeast 20
|> printfn "%A"

Переполнение стека. Есть какой-нибудь "стандартный" ленивый список, с unfold?

2 ответов

7 просмотров

Seq.unfold?

что здесь fairBind?

Похожие вопросы

Обсуждают сегодня

Если у меня есть такой класс: Object = {} function Object:new(a_name, a_transform, a_color, a_mesh, a_material, a_shader, a_textures) local private = {} private.n...
Cuarno Vile
4
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Добрый день! Подскажите, пожалуйста: какими компетенциями нужно обладать, чтобы претендовать на работу эрланг (отдельная благодарность, если про элексир тоже подскажете) разр...
via ☸️ led
20
Всем привет. Ребят подскажите пожалуйста. Вопрос по дизасемблировани. Начну с начала. У меня есть скомпилированная программа на ГО (я разработчик) - в ней есть защита лицензии...
Zloy
11
Можно попросить небольшое ревью кода? Тут немнога, я ничего интереснее не придумал, чем написать аналог tree в качестве практики с cmake. https://github.com/hrimov/tree-unix/...
Andrew Hrimov
11
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Карта сайта