gpt4 book ai didi

Haskell 模式匹配隐式类型

转载 作者:行者123 更新时间:2023-12-05 09:36:24 25 4
gpt4 key购买 nike

我是 Haskell 的新手,我正在尝试用模式匹配做一些事情。我什至不知道那样是否可行。我有一个数据 Fml :

    data Fml a = And (Fml a) (Fml a)
| NAnd (Fml a) (Fml a)
| Or (Fml a) (Fml a)
| NOr (Fml a) (Fml a)
| XOr (Fml a) (Fml a)
| XNOr (Fml a) (Fml a)
| Imply (Fml a) (Fml a)
| Equiv (Fml a) (Fml a)
| Not (Fml a)
| Final (Var.Var a)
deriving (Show)

Var 只是一个值(例如:1)我正在尝试制作一个简单的函数来将所有 Var 合并到一个数组中。我已经这样做了:

getVar :: (Eq a) => Fml a -> [Fml a]
getVar (And p q) = getVar p ++ getVar q
getVar (NAnd p q) = getVar p ++ getVar q
getVar (Or p q) = getVar p ++ getVar q
getVar (NOr p q) = getVar p ++ getVar q
getVar (XOr p q) = getVar p ++ getVar q
getVar (XNOr p q) = getVar p ++ getVar q
getVar (Imply p q) = getVar p ++ getVar q
getVar (Equiv p q) = getVar p ++ getVar q
getVar (Not p) = getVar p
getVar x = [x]

但我不满意,因为有 8 个案例都在做同样的事情。我想知道是否可以做这样的事情

getVar (_ p q) = getVar p ++ getVar q

最佳答案

您可以为运算符定义一个类型:

data <b>Op2</b> = And | NAnd | Or | NOr | Xor | XNor | Imply | Equiv

然后定义一个带有运算符和两个参数的数据构造函数:

data Fml a
= Fml2 <b>Op2</b> (Fml a) (Fml a)
| Not (Fml a)
| Final (Var.Var a)
deriving (Show)

那么你的函数看起来像这样:

getVar :: Eq a => Fml a -> [<b>Var.Var</b> a]
getVar (Fml2 _ p q) = getVar p ++ getVar q
getVar (Not p) = getVar p
getVar (Final v) = [v]

我认为输出类型应该是 Var.Var 的列表,而不是 Fml a,因为您的函数暗示它正在寻找一个列表变量。

关于Haskell 模式匹配隐式类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65168258/

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