|
Project #3 (Binary Search Trees) |
CMSC 132 |
|
Due Date: Thursday March 13, 6:00 pm |
Object-Oriented Programming II |
|
Type of Homework: Closed |
Spring 2008 |
Objective
The objective of this project to implement a polymorphic binary search tree. This project is designed to help you develop your skills at recursion, polymorphism and testing. This homework is considered a closed homework. Make sure you read the open/closed policy before continuing working on this project.
Any clarifications or corrections associated with this project will be available at: clarifications.html
Overview
For this project you must 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 this project can be found at
javadoc documentation.
Your project will be graded as follows:
Tests (75 %)
Public JUnit tests (3 %)
Release JUnit tests (30 %)
Secret JUnit tests ( 42 %)
Student Tests (20 %)
Style (5 %)
It is a required and graded part of your project that you develop and submit test cases that test your code. You only get the one test case in the class PublicTests, and the release tests all have unhelpful names such as testOne and testTwo. The TA's have been instructed that they should not help you debug your code unless you have written a test case on which your code misbehaves.
Using a code coverage tool, such as Clover, is one helpful tool to access whether your tests test all parts of your implementation.
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.
Remember you must provide your own tests.
The WordCountApplet uses a SearchTreeMap to count the number of times each word appears in the file specified by a URL. You may use the applet to gauge how well your SearchTreeMap implemention works, simply select "Run As"->"Java Applet", then type in the URL of a file you wish to analyze.
Here are some fun text files:
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.
There are a number of design restrictions you must obey in your implementation of EmptyTree and NonEmptyTree classes:
The above restrictions do not apply to your test cases; you may write them however you wish.
Honors Section
Students in the honors section must in addition compare the efficiency of SearchTreeMap and java.util.TreeMap classes for both sorted and unsorted inputs.
Submission
Submit your project using the submit project option associated with Eclipse.
Academic Integrity
Please make sure you read the academic integrity section of the syllabus so you understand what is permissible in our programming projects. We want to remind you that we check your project against other students' projects and any case of academic dishonesty will be referred to the University's Office of Judicial Program