Skip to content

Instantly share code, notes, and snippets.

@vlas-ilya
Created October 22, 2015 17:16
Show Gist options
  • Save vlas-ilya/35582d3fe1e5c3e9e93e to your computer and use it in GitHub Desktop.
Save vlas-ilya/35582d3fe1e5c3e9e93e to your computer and use it in GitHub Desktop.
Нумеруем узлы дерева с помощью монады State
traversalTree :: Tree () -> State Integer (Tree Integer)
traversalTree (Leaf _) = do
n <- get
put (n + 1)
return (Leaf n)
traversalTree (Fork left cur right) = do
left' <- traversalTree left
n <- get
put (n + 1)
right' <- traversalTree right
return (Fork left' n right')
numberTree :: Tree () -> Tree Integer
numberTree tree = evalState (traversalTree tree) 1
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment