diff options
| author | bringert <bringert@cs.chalmers.se> | 2006-03-20 14:46:47 +0000 |
|---|---|---|
| committer | bringert <bringert@cs.chalmers.se> | 2006-03-20 14:46:47 +0000 |
| commit | eacb437f437bc79650708af472b7796c7fd041e5 (patch) | |
| tree | 44d21f05cf6ea4f6a52c819488a31521ad6d22d7 /transfer/lib/bintree.tra | |
| parent | d760ce973896bbfd5e9f62516bb953cfeeabaf1a (diff) | |
Expermintation woth a collections framework for transfer.
Diffstat (limited to 'transfer/lib/bintree.tra')
| -rw-r--r-- | transfer/lib/bintree.tra | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/transfer/lib/bintree.tra b/transfer/lib/bintree.tra new file mode 100644 index 000000000..0dd21f184 --- /dev/null +++ b/transfer/lib/bintree.tra @@ -0,0 +1,22 @@ +-- NOTE: this is unfinished and untested + +import prelude + +data BinTree : Type -> Type where + Leaf : (A:Type) -> BinTree A + Node : (A:Type) -> BinTree A -> A -> BinTree A -> BinTree A + +contains : (A:Type) -> Ord A -> A -> BinTree A -> Bool +contains _ _ _ (Leaf _) = False +contains A o x (Node _ l y r) + | x < y = contains A o x l + | x > y = contains A o x r + | otherwise = True + +insert : (A:Type) -> Ord A -> A -> BinTree A -> BinTree A +insert A o x (Leaf _) = Node A (Leaf A) x (Leaf A) +insert A o x (Node _ l y r) + | x < y = Node A (insert A o x l) y r + | x > y = Node A l y (insert A o x r) + | otherwise = Node A l x r + |
