|
|
Project 2 - The search for a-MAZE-ing donuts!Phase AImportant Deadlines
Outline
I. IntroductionIt is an incredibly serendipitous day for you at the II. Learning ObjectivesIn this assignment, you will:
III. Assignment and Algorithm OverviewFor the complete assignment, you are required to write several new maze-solving MazeRunner classes. There should be one MazeRunner class for each of the following algorithms (subject to change in Phase B instructions):
IIIa. Phase A: Stacks, Queues, and PriorityQueuesDescriptionIn Phase A of this assignment, you will be writing code that implements a given (new) interface for a stack, queue, and priority queue (2 implementations). You should test these implementations to be sure they are correct before proceeding to Phase B (posted next week). In particular, you are required to design and implement a collection of JUnit tests that verify that your code works properly. Code RequirementsYour task for Phase A is to:
README.TXT QuestionsYou should turn in a README file with an informal description of your test plan. Summarize the tests you implemented and explain how they provide comprehensive test coverage for your classes. This should not just be a dump of the test names and comments from the code file - we can read that. What we want is to get an idea of the thinking behind what you did. IIIb. Phase B: Running the Maze (more later)Phase B will involve implementing the above tree traversal algorithms (they will be implemented as MazeRunner classes), understanding operations on a maze as a graph, and analyzing and extending the maze code which we will provide. IV. Logistics: TeamsYou are encouraged (although not required) to work with a partner of your own choosing for this project. You may choose how to divide the work between the two of you under three conditions: 1. You must document each team member's effort in the README file (record this now so you have the info for the phase B readme file); 2. Work together so that you both understand your answers to the questions answered in the README (for Phase B); 3. Understand (at least) at a high level how your team member's code is structured and how it works (code for both Phases A & B). If working with a partner, you must find your partner and send a single email to the instructor with the name AND UW email id of both partners by the deadline given at the top of this document. If you are planning on working alone, you should also email the instructor a message stating “I am working alone”. Remember to test your team's code as a whole to make sure that your portions work together properly! Also, be aware that except in extreme cases and provided you notify us in advance of the deadline, all team members will receive the same grade for the project. If you would like to use a shared group directory, please contact one of the TA's for instructions. This is NOT necessary, just optional if it is your preference. V. Phase A Provided CodeTo facilitate understanding of this rather complex project, and to encourage good modular decomposition and "unit testing" (testing small pieces of code instead of testing the entire program all at once), this project is broken into two Phases. For Phase A, we suggest improving and testing your basic "helper" data structures (i.e. Stack, Queue, BinaryHeap, ThreeHeap) without worrying about the Maze-related code. For this first Phase, we are providing the interfaces for a Stack, a Queue, and a PriorityQueue. You must write an implementation of the Stack and Queue interface as described above. In addition, you must write two implementations of the PriorityQueue interface – a BinaryHeap and a ThreeHeap. (For the ThreeHeap we suggest starting with a copy of your BinaryHeap code and making changes as necessary, although making the original code easy to generalize may save you time in phase B (hint, hint).). Java code: Right-click on the links below to download the starter code.
Your priority queue implementations must accept Comparable objects. Many classes
such as For Phase B of this project, we will be providing additional code which will read, parse, and build a Maze class object from a text file. We will also give a simple MazeRunner class from which you can inherit your own MazeRunners. VI. Phase A TurninPhases A and B will be graded together when your entire assignment is turned in with Phase B. However, 15% of your grade will be based upon the "in-progress" checkin for Phase A. Although 15% is a relatively small fraction, you are highly encouraged to successfully complete all of Phase A by this deadline, as there is much more work to do in Phase B. We will be testing the code that you submit for the in-progress checkin - so we will expect that you have done the same! Only one person from each team should submit. The same person should submit both Phases A and B. You should submit all of the Java code you wrote: MazeStack.java, MazeQueue.java, BinaryHeap.java, and ThreeHeap.java. |