Rev | Line | |
---|
[4] | 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.