两个参数的函数是否有>>=
?像
bind2 :: m a -> m b -> (a -> b -> m c) -> m c
答案 0 :(得分:5)
我不知道你可以使用哪些聪明的组合器来构建标准库,但是有可能说明显而易见的事情很容易实现:
bind2 :: Monad m => (a -> b -> m c) -> m a -> m b -> m c
bind2 f ma mb = do
a <- ma
b <- mb
f a b
> bind2 (\a b -> [a,b]) [1,2,3] [4,5,6]
[1,4,1,5,1,6,2,4,2,5,2,6,3,4,3,5,3,6]