gpt4 book ai didi

haskell - 比较 Haskell 中通配符的相等性..?

转载 作者:行者123 更新时间:2023-12-02 17:36:59 25 4
gpt4 key购买 nike

在Haskell中,有没有办法比较所有通配符是否具有相同的类型和值?例如,我想创建一个具有以下行为的函数:

(1 M) (2 M) (3 M) -> True
(1 S) (2 S) (3 S) -> True
(1 S) (2 M) (3 S) -> False

换句话说,第一个参数应该是1、2和3,第二个参数应该是全S或全M。

在这种情况下,我们也许可以编写一个函数,如下所示:

matches (1 _ ) (2 _ ) (3 _ )

但是,我们如何判断通配符是全S还是全M呢?

最佳答案

如果模式那么简单(全部为 M 或全部为 S),为什么不按原样定义它?

matches (1, M) (2, M) (3, M) = True
matches (1, S) (2, S) (3, S) = True
matches _ _ _ = False

或者还有其他限制吗?

关于haskell - 比较 Haskell 中通配符的相等性..?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1777679/

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