当我有一些类型的功能时
f :: (Ord a) => a -> a -> Bool
f a b = a > b
我想要用 not 包装这个函数的 make 函数。
例如制作这样的功能
g :: (Ord a) => a -> a -> Bool
g a b = not $ f a b
我可以使组合器像
n f = (\a -> \b -> not $ f a b)
但我不知道怎么做。
*Main> let n f = (\a -> \b -> not $ f a b)
n :: (t -> t1 -> Bool) -> t -> t1 -> Bool
Main> :t n f
n f :: (Ord t) => t -> t -> Bool
*Main> let g = n f
g :: () -> () -> Bool
我究竟做错了什么?
还有一个额外的问题,我如何为具有更多和更少参数的函数做到这一点,例如
t -> Bool
t -> t1 -> Bool
t -> t1 -> t2 -> Bool
t -> t1 -> t2 -> t3 -> Bool