在没有回答键的情况下填写学习指南。我需要使用一行中的map将函数列表(fs)中的每个函数应用于值(v)
applyEach :: [a->b] -> a -> [b]
applyEach fs v = map (\v -> fs v) fs
这是我能得到的。我知道我不能将fs应用于某个值,因为fs是函数列表,但我不知道如何使用列表中的每个函数
答案 0 :(得分:9)
您可以使用$
(f $ x = f x
):
Prelude> let fs = [(+1), (+2)]
Prelude> map (\f -> f 2) fs
[3,4]
Prelude> map ($ 2) fs
[3,4]
这是有效的,因为($ x)
是section相当于\f -> f $ x
,等同于\f -> f x
(地图中的函数)
或者,您可以导入Control.Applicative
并使用<*>
和列表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]
答案 1 :(得分:3)
($ v)
是一个函数,在函数f
的情况下,它会计算f v
。所以,只需将其映射到fs
:
map ($ v) fs