将每个函数应用于列表Haskell的每个元素

时间:2014-04-24 19:06:57

标签: haskell

我有一个像这样的函数列表:

  

[(+ 1),(+ 2),(* 4),(^ 2)]

我想将每个函数应用于另一个列表的每个元素。例如,我有一个这样的列表[1..5],我希望得到这个结果:[2,4,12,16]

这是我已经尝试过的。

applyEach :: [(a -> b)] -> [a] -> [b]
applyEach _ [] = []
applyEach (x:xs) (y:ys) = x y : applyEach xs ys

我不知道是什么问题,我们有一个在线表面,我们必须放置代码并测试我们的submision,并且只说我的代码没有通过。

2 个答案:

答案 0 :(得分:8)

当列表长度相同或第二个列表比第一个列表短时,您的功能正常工作:

> applyEach [(+1), (+2), (*4), (^2)] [1..4]
[2,4,12,16]
> applyEach [(+1), (+2), (*4), (^2)] [1..3]
[2,4,12]

但是你并没有处理第二个列表更长的情况,就像你的例子一样:

> applyEach [(+1), (+2), (*4), (^2)] [1..5]
[2,4,12,16*** Exception: H.hs:(2,1)-(3,47): Non-exhaustive patterns in function applyEach

您需要在函数中再添加一个等式来处理这种情况。

答案 1 :(得分:6)

您也可以使用内置的zipWith函数和$运算符执行此操作:

applyEach fs xs = zipWith ($) fs xs