Department of Computer
Science
CMSC132
Spring 2019
Project: Binary Search Tree
Due Date: Sunday 4/14, 11:00 pm
Assignment Type: Closed
You will implement the methods of the EmptyTree and NonEmptyTree classes. We have provided a Tree interface and a partial implementation of the SearchTreeMap class (you must implement the keyList and subMap methods). Complete documentation for these classes can be found at javadoc documentation.
The objective of this project is to implement a polymorphic binary search tree. This project is designed to help you develop your skills at recursion, polymorphism and testing.
As always, you are expected to develop test cases that test your code. You only get a few test cases in the class PublicTests, and the release tests all have unhelpful names such as testOne and testTwo.
In addition to the release tests, there are additional secret test cases. Don't assume that just because your implementation passes the release tests, it is correct.
The WordCountApplet is not really part of this assignment, but it has been provided for fun. This applet uses a SearchTreeMap to count the number of times each word appears in the text file specified by a URL. You may use the applet to gauge how well your SearchTreeMap implemention works. The default URL is a text file containing the complete works of Shakespeare (give it a few seconds to load after pressing the button!) Of course you may enter any URL you wish into the box.
The SearchTreeMap class implements some of the functionality of the Map interface (although not all). A SearchTreeMap object is just a wrapper around a Tree, which is actually used to implement binary search trees.
Note that the insert and delete methods on Tree objects return references to Tree objects. In many cases, these functions may return a reference to the this object. However, in some cases they can't. For example. EmptyTree.getInstance.insert("a", "1") has to return an instance of an NonEmptyTree object.
You are expected to use polymorphism (and exception handling, where appropriate) to handle the differences between empty and nonempty trees. Failure to do so will result in a large negative adjustment to your project grade.
The above restrictions do not apply to your test cases; you may write them however you wish.