Haskell列表问题

时间:2014-03-29 18:25:32

标签: list haskell list-comprehension

我是Haskell的新手,我正在尝试编写一个简单的函数,它接受一个整数列表并返回一个列表,以便将第一个元素添加到列表的所有元素中。

这是我到目前为止所做的。

addFirstEl [] = []
addFirstEl (x:xs) = [x + x | x <- xs]

不幸的是,所有this成功完成的工作都是返回一个没有第一个元素而其他元素加倍的列表。

2 个答案:

答案 0 :(得分:6)

x在列表推导中的绑定隐藏了模式中的变量x。试试这个:

addFirstEl [] = []
addFirstEl (x1:xs) = [x1 + x2 | x2 <- xs]

修改

回复你的评论

  

第一个元素仍然从返回的列表中删除

(x1:xs)中,xs是列表的余数或tail。它是x1之后的所有元素,即head。如果您想将x1添加到包括其自身在内的所有元素,您可以编写

addFirstEl [] = []
addFirstEl (x1:xs) = [x1 + x2 | x2 <- (x1:xs)]

head

addFirstEl [] = []
addFirstEl xs = [head xs + x | x <- xs]

答案 1 :(得分:3)

试试这个:

addFirstEl [] = []
addFirstEl l@(x:_) = [x + x1 | x1 <- l ]

addFirstEl [] = []
addFirstEl l@(x:_) = map (+ x) l