0

我有一个函数可以转换 [a, b, c, d, . . . ] 到 [(a,b), (c, d), . . .]。现在这工作了,这里是代码:

makeTuple :: [a] -> [(a,a)]
makeTuple [] = []
makeTuple [a] = []
makeTuple (x:y:xs) = (x,y): (makeTuple xs)

现在我要做的下一件事是:使用前面的函数,使用 foldl 和 lambda 表达式将每个元组转换为其两个元素的乘积。这就是我所拥有的:

productTuple [x] = foldl makeTuple [] [x]

现在我不确定这是否正是我所要求的。我不确定是否应该使用类型声明和诸如此类的东西创建一个单独的函数。也许有人可以告诉我这是否是解决这个问题的最佳方法。此代码也不起作用,我不知道为什么,我需要这部分的帮助。(请注意,它说要使用 lambda,但我不知道如何真正正确地使用它们,这是我需要帮助的另一部分)我真的很感激,谢谢。

4

2 回答 2

0

lambda 函数应该尊重这个签名:

 [a] -> (b,b) -> [a]

累加器的类型为 [a],元组的类型为 (b,b)

你可以试试这样的 lambda\acc (a, b) -> acc++[a*b]

最终功能可能如下所示:

productTuple :: Num a => [a] -> [a]
productTuple xs = foldl (\acc (a, b) -> acc++[a*b]) [] (makeTuple xs)

你在这里有一些foldl 函数的例子

我在这里尝试了这段代码

于 2017-11-02T15:43:40.047 回答
-1

该练习要求您使用 预处理输入列表makeTuple,然后将其折叠起来。

productTuple :: [Int] -> [Int]
productTuple xs = foldl (some lambda) something (makeTuple xs)

这不是最方便的方法,但我想练习的目的是强迫你foldl只是为了它而使用它。

于 2017-11-02T08:29:53.160 回答