Problem
Within the linked data structure for binary trees, explore an alternative design for implementing the iterators returned by the methods iterator(), positions().iterator(), and children(v).iterator() such that each of these methods takes O(1) time. Can you still achieve constant time implementations for the methods hasNext() and next() of the iterators returned?