Assignment 6: Tests, BSTs, and Efficient Maps with Comparable Keys
This is assignment is to be completed and submitted individually. You may not work with anyone else.
Due: Tuesday, April 9, 11:59:59 PM EST.
1 Revising a Library of Data structures
For this assignment, you must revise your library of data structures for maps, sets, and multisets.
1.1 Passing the Test Suite
Here is a test suite for your solution to assignment 5: Assign5.java. You can add it to your project and run it on your own code to see how your implementation stacks up.
To get full credit on this assignment, you must pass all of the test suite tests (this is necessary for full credit, but not sufficient; you must also submit well-designed code.)
1.2 Adding BSTs and MapComps
You must also implement a new data structure: binary search trees (BSTs) and maps built using BSTs.
Add the following BST.java code to your project and implement all of the methods in the interface using the provided classes. You may add any methods you like, but you may not remove or change any of the signatures given in the interface.
Every BST object should satisfy the BST invariant which is the following property:
A BST b has the BST property if and only if: (a) it is a leaf or (b) it is a node and for all values in the left subtree, they compare as smaller or equal (using the Java built-in Comparable interface) as the value in the node and for all values in the right subtree, they compare as greater than the value in the node.
Once you have a working BST implementation, add the MapComp.java code to your project.
The idea behind a MapComp object is that it implements a map-like data structure in that it maps unique keys to values, but it requires the keys to be comparable. Therefore, it can create a binary search tree of pairs of keys and values and use this data structure to implement some map operation much more efficiently than using, e.g. a list.
You are given an interface and the start of a class that implements the interface. Your solution must represent a MapComp using the data representation given to you. You may add any methods you need, but again, do not change or remove anything from the interface.
Note that the map and mapMono methods will be discussed on Wednesday.
Submission
Use submit.cs.umd.edu to submit your solution to the problems. You should create a zip file called Assign6.zip that contains the IntelliJ project containing your solutions.