gpt4 book ai didi

haskell - 导出 ((.) foldr) 的类型

转载 作者:行者123 更新时间:2023-12-04 16:45:21 25 4
gpt4 key购买 nike

我正在尝试手动导出 ((.) foldr) 的类型

(.) ::(b1 -> c1) -> (a1 -> b1) -> a1 -> c1
foldr :: (a2 -> b2 -> b2) -> b2 -> [a2] -> b2

然后:

b1 = a2 -> b2 -> b2
c1 = b2 -> [a2] -> b2

匹配我得到的类型:

((a2 -> b2 -> b2) -> (b2 -> [a2] -> b2)) -> (a1 -> (a2 -> b2 -> b2)) -> a1 -> (b2 -> [a2] -> b2)

但后来我对如何减少这种表达感到困惑。

有什么帮助吗?

谢谢,
塞巴斯蒂安。

最佳答案

您正确地计算出了 (.) foldr(.) 的类型。 (.) 应用于一个参数(foldr),因此您可以丢弃 ((a2 -> b2 -> b2) -> (b2 -> [a2] -> b2)) 剩下的就是 (.) foldr 的类型:

(a1 -> a2 -> b2 -> b2) -> a1 -> (b2 -> [a2] -> b2)

确保 foldr 可以在你之前输入 ((a2 -> b2 -> b2) -> (b2 -> [a2] -> b2))把它扔掉。如果匹配正确,此检查不会失败,但它是一个很好的完整性检查。

关于haskell - 导出 ((.) foldr) 的类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23415155/

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