This lab is a stepping stone for the Segment Intersection Project.
The lab is to finish a BinaryTree
class that implements the
Sequence
and ReverseSequence
interfaces. These interfaces are defined in terms of iterators, Iterator
and ReverseIterator
. Traversing according to the Sequence
should provide an inorder traversal. Traversing according to the
ReverseSequence
should provide a backwards inorder traversal.
- Student support code is at link.
- Submit your code file
BinaryTree.java
(Problem 1) to link. - Submit your test file
BinaryTreeTest.java
(Problem 2) to link.
The first step is to implement next
and previous
methods in the
Node
class (which is nested inside the BinaryTree
class).
We recommend that you start by implementing the following helper
functions in the Node
class, which come in handy when trying to move
forwards or backwards within the binary tree:
public Node first();
first()
: returns the first node in the current subtree according to an inorder traversal.
public Node last();
last()
: returns the last node in the current subtree according to an inorder traversal.
public Node nextAncestor();
nextAncestor()
: returns the first ancestor that is next with respect to an inorder traversal ornull
if there is none.- We recommend that you use the
parent
field that has been added to theNode
class for this purpose.
- We recommend that you use the
public Node prevAncestor();
prevAncestor()
: returns the first ancestor that is previous with respect to and inorder traversal or null if there is none.- Again, you'll need to use the
parent
field to walk up the tree.
- Again, you'll need to use the
Once the above helper functions are complete, it is straightforward to implement methods that return the next and previous nodes according to an inorder traversal:
public Node next();
public Node previous();
- The idea for
next()
is that:
- if the current node has a right child, then the
first()
of that child's subtree is the next node. - if the current node does not have a right child (if it is
null
), then the next node is it'snextAncestor()
.
- The idea for
previous()
is the mirror image of the idea fornext()
.
You can now move on to finish the implementation of the Iter
class
(which is nested inside the BinaryTree
class) by filling in:
get()
: returnsdata
of the current nodecurr
retreat()
: as its name suggests, sets the current node to be the previous node ofcurr
advance()
: sets the current node to be the next node ofcurr
equals()
: ifcurr
of thisIter
is equal to thecurr
of the otherclone()
: returns a new iterator that copiescurr
These methods are 1-liners.
Write test cases in BinaryTreeTest.java
with one method named test()
.
This method should thoroughly test the BinaryTree
class.
Test and debug your own code from Problem 1 locally and then submit both your code and your test cases to Autograder for grading.
The Autograder will apply your tests to buggy implementations of the
BinaryTree
class. You receive 1 point for each bug detected.
The Autograder will also apply your tests to a correct implementation
to rule out false positives.
- You have reached the end of Lab 3. Yay!