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

Народ, есть такой код: dividers n = filter ((== 0) .

mod n) $ [1..n-1]
partitions [] = [[]]
partitions (x:xs) = partitions xs >>= (\sub -> [sub, x:sub])
sumDivSet n = filter ((== n) . sum) . partitions $ dividers n
main = putStrLn . unlines . map show $ ((zip <*>) . map) sumDivSet list
where list = [1..400 :: Int]
Он нормально, быстро работает. Если же заменить определение partitions на, вроде бы, эквивалентное
partitions = filterM $ const [False, True]
, то скорость кода заметно падает. Скажите, пожалуйста, с чем это может быть связано?

2 ответов

3 просмотра
Антон-🇦🇲 Автор вопроса

Выглядит так, как будто упускается возможность для fusion-а. Или эти определения имеют неодинаковую семантику по отношению с ленивости?

Антон-🇦🇲 Автор вопроса

Всё-таки, почему такая существенная разница в производительности?

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

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

Такс, блин, таки кто-то знает, каким образом работают макросы stdin/stdout/stderr? Я влез в stdio.h, там определения нет, отладил через асмокод - вызывается функция со странны...
The Bird of Hermes
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Всем привет, на линуксе лучше на fasm или nasm учиться писать для начала ?
meszjol
14
Если у меня есть такой класс: 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
было так ;void set_http_ver(RESPD* ptr, char* version, uint32_t length) // example: 'RTSP/1.1 ' set_http_ver: mov eax, [esp + 4] mov ecx, [esp + 8] ...
Mixail Frolov
5
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
Code Explorer / обновление содержимого окна, задержка - задержка, по моему, слишком большая, примерно 1 сек, хотелось-бы установить - макс. быстро - в настройках ide не нашел...
livontiy
1
Карта сайта