gpt4 book ai didi

haskell - 无法理解简单的 Haskell 编译错误

转载 作者:行者123 更新时间:2023-12-02 05:38:29 26 4
gpt4 key购买 nike

我目前正在学习 Haskell。我正在尝试编写一个函数,如果一个是另一个的排列,则给定两个 n 个不同元素的列表返回 true。我这样做是为了练习。

我先写成:

isPermut :: (Eq a)=>[a]->[a]->Bool
isPermut u v = foldl (\acc x -> acc && (elem x u)) True v

这似乎有效。我现在尝试在没有 lambda 表达式的情况下重写它。所以我尝试:

isPermut :: (Eq a)=>[a]->[a]->Bool
isPermut u v = foldl (&& (flip $ elem u)) True v

这给了我一个编译错误:

Couldn't match expected type `b0 -> Bool' with actual type `Bool'
Expected type: Bool -> b0 -> Bool
Actual type: Bool -> Bool
In the first argument of `foldl', namely `(&& (flip $ elem u))'
In the expression: foldl (&& (flip $ elem u)) True v

这个错误是什么意思?在没有 lambda 的情况下编写函数的正确方法是什么?谢谢。

最佳答案

折叠必须采用两个参数的函数。因为 (&& whatever)\x -> x && whatever 相同,所以你给出了一个函数 one 参数。

为了不在这里使用 lambda,你需要一些方法来组合 &&,一个双参数函数,(`elem` u),一个单参数功能。 (注意 (`elem` u)(flip elem) u\x -> elem x u 相同。)

关于haskell - 无法理解简单的 Haskell 编译错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9135045/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com