asg8

advertisement

Computer Programming I

COP 2210

Instructor: Greg Shaw

Programming Assignment #8

"The ArrayList Class"

I.

The Term Class

Create a class to represent a term in an algebraic expression.

As defined here, a term consists of an integer coefficient and a nonnegative integer exponent. E.g.

 in the term 4x

2

, the coefficient is 4 and the exponent 2

 in -6x

8

, the coefficient is -6 and the exponent 8

Your Term class will have a constructor that creates a Term object with a coefficient and exponent passed as parameters, accessor methods that return the coefficient and the exponent.

Your class will also have a toString() method that returns a

Term object as a String, formatted as shown in these examples:

Coefficient

5

8

4

Exponent

3

1

0 returns

5x^3

8x

4

II.

The Polynomial Class

Now create a class to represent a polynomial. As defined here, a polynomial is a sequence of terms. E.g.

1.

3x 2 + 4x 4 + x 6

2.

2 + 5x 2 + 6x 3 + 2x 7

3.

4x 10

The terms of polynomial 1 are (3,2), (4,4) and (1,6). The terms of polynomial 2 are (2,0), (5,2), (6,3) and (2,7).

Polynomial 3 has only one term (4,10)

To receive credit for this assignment, your class must use a generic “ArrayList of Term” to store the terms of a

Polynomial object

Your class will have a constructor that creates an empty list and additional methods to do each of the following:

1.

insert a new term in its proper place in a polynomial (see

“Additional Specifications,” below)

2.

return all the terms of a polynomial as a single line string, as shown here:

3x^2 + 4x^4 + x^6

Hint: for each Term in the Polynomial, call the toString() method of the Term class and concatenate

3.

delete a term from a polynomial (see “Additional

Specifications,” below)

4.

compute and return the product of all the terms of a polynomial

5.

reverse the order of the terms in a polynomial (see

“Additional Specifications,” below)

III.

The Test Class

The main method of your test class will create a Polynomial object and then read and process a series of operations until end of file.

The operations are:

1 . INSERT X Y

Insert a new term with coefficient X and exponent Y into its proper place in the polynomial

2. DELETE X Y

Remove the term with coefficient X and exponent Y from the polynomial

3. REVERSE

Reverse the order of the terms of the polynomial

4. PRODUCT

Compute and return the product of all the terms

Each operation is to be carried out by calling a method of the Polynomial class

Each operation read must be “echo printed” to the screen

After each operation, print the updated polynomial by calling the toString() method

For the PRODUCT operation, print the string returned

IV.

Additional Specifications

1.

All instance variables must be private

2.

The skeleton of the Polynomial class you are to use is online. No credit will be given if the method declarations are changed in any way

3.

The operations are to be read from a data file which I will provide

4.

You may assume correct input

5.

Also assume that no insertions will be made into a reversed polynomial. (But you might want to think about how this could be accomplished)

6.

Regarding the delete() method: if the specified term does not occur in the polynomial then print an appropriate message

7.

Regarding the reverse() method: you must write your own algorithm to reverse the order of the elements of an

ArrayList. No credit will be given for calling the reverse method of Java’s Collections class or any other method. No credit will be given for merely printing the terms in reverse order.

(Hint: You may want to use a temporary ArrayList to create the reversed list)

8.

Regarding the insert() method: The terms of a polynomial are to be inserted in ascending order by exponent. There will never be a need to “sort” the list. Multiple terms with the same exponent may appear in any order, but will appear after all terms with a lesser exponent and before all terms with a greater exponent

An algorithm to insert a term in its proper place in an ordered list will be discussed in class

9.

For maximum credit, make sure your classes adhere to all the style and documentation standards presented in Unit 6 and discussed in class. (Note that the Javadoc comments for the Polynomial class have already been done)

V.

What to Upload

Upload a zip file containing your 3 .java files and the program output

VI.

Due Date – Thursday, April 23

rd

Because this is the last day of class and we have two full weeks to complete it, late assignments will not be accepted.

However, partial credit will be given for all methods that work correctly.

Download