| Line | |
|---|
| 1 | #ifndef __BINMEMOISE_H__ |
|---|
| 2 | #define __BINMEMOISE_H__ |
|---|
| 3 | #include "delegate.h" |
|---|
| 4 | #include "bintree.h" |
|---|
| 5 | |
|---|
| 6 | template<typename T> |
|---|
| 7 | BinTree<T> code(Fun1<T, Int> fun) |
|---|
| 8 | { |
|---|
| 9 | return mkLazy(mkFun([] (Fun1<T, Int> fun) { |
|---|
| 10 | auto val = mkLazy(mkFun([] (Fun1<T, Int> fun) { return fun.invoke (Ref::mk (0L)); })); |
|---|
| 11 | auto lFun = mkFun1([] (Fun1<T, Int> fun, R<Int> n) { return fun.invoke (Ref::mk (*n * 2L + 1L)); }); |
|---|
| 12 | auto rFun = mkFun1([] (Fun1<T, Int> fun, R<Int> n) { return fun.invoke (Ref::mk (*n * 2L + 2L)); }); |
|---|
| 13 | return Ref::mk <BinTree<T>> (code(lFun), val, code(rFun)); |
|---|
| 14 | }, fun)); |
|---|
| 15 | } |
|---|
| 16 | |
|---|
| 17 | template<typename T> |
|---|
| 18 | Fun1<T, Int> decode(BinTree<T> tree) |
|---|
| 19 | { |
|---|
| 20 | return mkFun1([] (BinTree<T> tree, R<Int> n) |
|---|
| 21 | { |
|---|
| 22 | if (*n == 0L) |
|---|
| 23 | { |
|---|
| 24 | return tree->get(); |
|---|
| 25 | } |
|---|
| 26 | else if (*n % 2L == 1L) |
|---|
| 27 | { |
|---|
| 28 | return (decode (tree->getLeft())).invoke (Ref::mk ((*n - 1L) / 2L)); |
|---|
| 29 | } |
|---|
| 30 | else |
|---|
| 31 | { |
|---|
| 32 | return (decode (tree->getRight())).invoke (Ref::mk ((*n - 2L) / 2L)); |
|---|
| 33 | } |
|---|
| 34 | }); |
|---|
| 35 | } |
|---|
| 36 | |
|---|
| 37 | #endif |
|---|
Note: See
TracBrowser
for help on using the repository browser.