Computer Programming II Instructor: Greg Shaw

Total Page:16

File Type:pdf, Size:1020Kb

Computer Programming II Instructor: Greg Shaw

Computer Programming II Instructor: Greg Shaw COP 3337

Programming Assignment #2

(Arrays)

I. The Assignment

The Bashemin Parking Garage contains a single lane that can hold up to ten cars. Arriving cars enter the garage at the rear and are parked in the empty space nearest to the front. Departing cars exit only from the front.

If a customer needs to pick up a car that is not nearest to the exit, then all cars blocking its path are moved out temporarily, the customer's car is driven out, and the other cars are restored in the order they were in originally. Whenever a car departs, all cars behind it in the garage are moved up one space.

Write a Java program to operate the garage.

The program will read and process lines of input from a file until end-of-file. Each input line contains a license plate number and an operation (ARRIVE or DEPART), separated by spaces. Cars arrive and depart in the order specified by the input. Each input operation must be “echo printed” to an output file, along with an appropriate message showing the status of the operation.

 When a car arrives, the message will include the license number and state whether the car is being parked or turned away because the garage is full. If the garage is full, the car leaves without ever having entered the garage.

 When a car departs, the message will include the license number and the number of times the car was moved.

The number of moves does not include the one where the car departs from the garage, or the number of times the car was moved within the garage. It is only the number of times it was moved out of the garage temporarily to allow a car behind it to depart. If a DEPART operation calls for a car that is not in the garage, the message should so state. II. Specifications 1. Create separate classes to implement a Car and a Garage 2. The Car class will have private instance variables that store the license number and number of times the car has been moved, and any methods you discover to be necessary 3. The Garage class must use an array (not an ArrayList) of Car objects to implement the garage 4. To handle the arrival and departure of each car, your Garage class must implement separate methods arrive() and depart(), each of which returns a String showing the result of the operation (see above). 5. Your garage class may contain other methods should you find them necessary or advisable. 6. Also write a “test” class that reads the operations from the input file, echoes each to the output file, calls the appropriate Garage class method, and writes the String returned to the output file. 7. As stated in 4. and 6. above, all output is to be done in the test class. None of the Garage or Car class methods do any output 8. Make sure your classes adhere to the style and documentation standards discussed in class and in online notes

III. Data File The input file - garage.txt - is available on the class web page

IV. Due Date: Tuesday, February 13th

V. What to Upload to Moodle Upload a zip file containing your NetBeans project folder with the output file. Make sure you zip the project folder itself, and not the individual .java files. No other kinds of compressed files will be accepted other than .zip. See the “Submitting Your Assignments” document online

To receive credit for this assignment you must declare the garage array with an initial size of 10 and must not resize it! I.e. you must use a counter to keep track of the number of cars in the garage, as shown in classes PartiallyFilled.java and OrderedList.java. No credit will be given if you use an array with size of 1 and then resize it by adding one more element for each arriving car. This is grossly inefficient and simply not done in this quadrant of the galaxy. Counters are a fundamental concept of programming. Use them. Love them.

Recommended publications