繁体   English   中英

Haskell foldl Monad绑定

[英]Haskell foldl Monad bind

我有一个功能

move :: Move -> Node -> Maybe Node

在这里我可以使用我的绑定单子来获取Maybe Node

(return n >>= move m) 

其中n :: Node和m :: Move,但是现在如何折叠Move([Move])列表?

我试图用折叠来做,但是没有成功。

如果您有一个初始Node和一个[Move] ,则可以使用foldM

moveAll :: Node -> [Move] -> Maybe Node
moveAll startNode moves = foldM (\n m -> move m n) startNode moves

或简单地

moveAll = foldM (flip move)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM