填写一份没有答案的学习指南。我需要使用一行map将函数列表(fs)中的每个函数应用于值(v)。
applyEach :: [a->b] -> a -> [b]
applyEach fs v = map (\v -> fs v) fs
这是我所能得到的。我理解不能将fs应用于值,因为fs是函数的列表,但我不知道如何使用列表中的每个函数
发布于 2014-03-27 17:22:28
为此,可以使用$
(f $ x = f x
):
Prelude> let fs = [(+1), (+2)]
Prelude> map (\f -> f 2) fs
[3,4]
Prelude> map ($ 2) fs
[3,4]
这是因为($ x)
是一个与\f -> f $ x
等价的section,它相当于\f -> f x
(映射中的函数)。
或者,您可以导入Control.Applicative
并使用<*>
和list Applicative
实例:
Prelude Control.Applicative> let fs = [(+1), (+2)]
Prelude Control.Applicative> map (\f -> f 2) fs
[3,4]
Prelude Control.Applicative> fs <*> [2]
[3,4]
发布于 2014-03-27 17:24:05
($ v)
是一个函数,给定一个函数f
,计算f v
。所以,只需在fs
上映射
map ($ v) fs
https://stackoverflow.com/questions/22702455
复制相似问题