我想要一个带有两个任意类型列表并返回一个(即f:: [[a]] -> [[a]] -> [[a]]
)的函数。基本上,也会产生两个输入列表的“连接”。Haskell中列表的连接
例如
> f [[1,2,3], [123]] [[4,5,6], [3,7]]
[[1,2,3,4,5,6], [1,2,3,3,7], [123,4,5,6], [123,3,7]]
目前,我已经用它走到这一步:
f _ [] = []
f [] _ = []
f (xs:xss) (ys:yss) = ((xs ++ ys) : [m | m <- f [xs] yss])
但是这并没有考虑到xss
和是错误的。有什么建议么?
或只是'liftA2(++)' – luqui 2012-03-13 22:14:54