我一直在考虑如何实现unfold
以下类型的等价物:
data Tree a = Node (Tree a) (Tree a) | Leaf a | Nil
这不是很明显,因为unfold
列表的标准返回一个值和下一个种子。对于这种数据类型,它没有意义,因为在到达叶节点之前没有“值”。这样,只有返回新种子或以值停止才真正有意义。我正在使用这个定义:
data Drive s a = Stop | Unit a | Branch s s deriving Show
unfold :: (t -> Drive t a) -> t -> Tree a
unfold fn x = case fn x of
Branch a b -> Node (unfold fn a) (unfold fn b)
Unit a -> Leaf a
Stop -> Nil
main = print $ unfold go 5 where
go 0 = Stop
go 1 = Unit 1
go n = Branch (n - 1) (n - 2)
虽然这似乎可行,但我不确定这是否应该是这样。所以,这就是问题:正确的方法是什么?