联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Java编程Java编程

日期:2018-09-29 09:49

Implementing Polynomials in Java

Introduction

A polynomial,

P x( )

, is a mathematical function of the form:

0

( )

d

i

i

i

P x a x

?

? ?

The degree, d, of the polynomial is the largest exponent in any of the terms of the polynomial. For

example, the largest exponent in

3 2 P x x x ( ) 2 4 1 ? ? ?

is 3, meaning that

3 2 P x x x ( ) 2 4 1 ? ? ?

is a cubic

polynomial. It is customary to write the term with the largest exponent first, followed by the term

with the next largest exponent and so on, with the constant term (which you can think of as the term

with exponent 0) appearing last. You may assume for the purposes of this assignment that all the

exponents are positive valued or 0.

The constants

0 1 , , , d

a a a

are the coefficients of the polynomial. The coefficients can be positive,

negative or zero (except for the term with d as its exponent – the coefficient of that term cannot be

zero). For example, the coefficients of

3 2 P x x x ( ) 2 4 1 ? ? ?

are 2, -4 and 1. Note that the coefficient

of the

x

term in

3 2 P x x x ( ) 2 4 1 ? ? ?

is 0.

In the first part of this assignment, you are required to develop your own classes to represent

polynomials in Java as double linked lists. The diagram below illustrates how the polynomial

3 2 P x x x ( ) 2 4 1 ? ? ?

is implemented as a linked list.

2

3

previous null

next

coefficient

exponent

-4

2

previous

next

coefficient

exponent

1

0

null

previous

next

coefficient

exponent

head

Notice that in the linked list:

? The list has as many nodes as there are terms in the polynomial.

? Each node in the linked list contains a value for the coefficient and a value for the exponent.

? The nodes in the linked list are ordered. Nodes with a higher exponent precede nodes with a

lower exponent (this is in keeping with the convention that terms with higher exponent are

written first).

? The constant term has an exponent of 0.

? Other than the first and last nodes in the linked list, each node references the previous node

and the next node in the list.

Page 2 of 4

? The reference to the previous node in the head of the list is set to null.

? The reference to the next node in the tail of the list is set to null.

In the second part of this assignment you will also need to implement the methods necessary to add,

subtract and multiply any 2 polynomials. Recall that only the ‘like’ terms (the terms with the same

variables and exponents) of a polynomial are added or subtracted. We commonly refer to the process

of adding or subtracting ‘like’ terms as ‘collecting like terms’. For example, if

2

1P x x x ( ) 4 3 2 ? ? ?

and

2

2 P x x x ( ) 2 1 ? ? ?

then

2 2

1 2

2 2

2

( ) ( ) 4 3 2 2 1

4 3 2 2 1

5 5 3

P x P x x x x x

x x x x

x x

? ? ? ? ? ? ?

? ? ? ? ? ?

? ? ?

To multiply 2 polynomials each term of the first polynomial is multiplied by each term in the second.

You then need to collect like terms so that there is only one term for each exponent. For example, if

2

1P x x x ( ) 3 ? ?

and

2 P x x ( ) 2 1 ? ?

then

? ? ? ?

2

1 2

2 2

3 2 2

3 2

( ) ( ) 3 2 1

2 1 3 2 3 1

2 6 3

2 7 3

P x P x x x x

x x x x x x

x x x x

x x x

? ? ? ? ?

? ? ? ? ? ? ? ?

? ? ? ?

? ? ?

Three classes are provided for you: PolyList, PolyNode, and PolyOpps. PolyList contains the

methods and fields for creating a double linked list of polynomial terms. PolyNode defines the fields

of the nodes in the linked list. PolyOpps contains the methods for adding, subtracting and multiplying

polynomials. You may add extra classes and you may add your own variables and methods to the

classes supplied. You MUST NOT change the existing variables and method signatures. If you

change them the automated marking program cannot check your submission and you will lose marks

as a result.

Part A: Representing a polynomial as a linked list

1. Write code for the addNode method in the PolyList class that inserts the new node in its

correct position in linked list (that is, all nodes before the new node in the list have larger

exponents and all nodes after the new node have smaller exponents). For example, addNode

should add a node for the

2

x

term after the node for the

3

x

term in the list but before the node

for the

x

term. If the list is empty then addNode should set the node as the head of the list.

addNode should return true if it successfully added the new node to the linked list. It should

return false and leave the linked list unchanged if the list already contains a node with the

same exponent. (15 marks)

2. Add code to the getDegree method that returns the degree of the polynomial. If the linked list

is empty then getDegree should return -1. (5 marks)

3. Implement the getNode method in the PolyList class. getNode should return a reference to

this node in the linked list that contains the specified exponent. getNode should return null if

no node in the list has the specified exponent. (10 marks)

4. Write code for the reduce method in the PolyList class that removes nodes from the linked list

with a coefficient of 0. The reduce method should leave the linked list unmodified if there are

Page 3 of 4

no nodes with a coefficient of 0. For example, the reduce method removes the middle node

that has a coefficient of 0 from the linked list below. (14 marks)

Linked list before reduce method:

2

3

previous null

next

coefficient

exponent

0

2

previous

next

coefficient

exponent

5

1

null

previous

next

coefficient

exponent

head

Linked list after reduce method:

2

3

previous null

next

coefficient

exponent

5

1

null

previous

next

coefficient

exponent

head

5. Implement the toString method so that it returns a string representation of the polynomial.

This must be completed for the testing program to correctly display. For a polynomial of

degree d, toString should return a string in the form:

a x d a x d a x d d ^ ^ 1 ^ 0 ? ? ? ? ?1 0 ? ?

For example, your toString method should return the string:

"2 ^ 3 1 ^ 2 6 ^1 3 ^ 0" x x x x ? ? ?

to represent the polynomial

3 2 P x x x x ( ) 2 6 3 ? ? ? ? . (10 marks)

Page 4 of 4

Part B: Adding, subtracting and multiplying polynomials

1. Implement the addPolys method of PolyOpps to add any 2 polynomials. Note that the

polynomials may not have the same degree. If either method argument is null, or if either

input polynomial contains one or more negative exponents then addPolys should throw an

IllegalArgumentException. If the method arguments are valid then addPolys should add the 2

polynomials and return a reference to a new linked list containing the resultant polynomial.

(14 marks)

2. Implement the subtractPolys method of PolyOpps to subtract any 2 polynomials. If either

method argument is null, or if either input polynomial contains one or more negative

exponents then subtractPolys should throw an IllegalArgumentException. If the method

arguments are valid then subtractPolys should subtract the 2 polynomials and return a

reference to a new linked list containing the resultant polynomial. (14 marks)

3. Write code in the multiplyPolys method of PolyOpps to multiply any 2 polynomials. If either

method argument is null, or if either input polynomial contains one or more negative

exponents then multiplyPolys should throw an IllegalArgumentException. If the method

arguments are valid then multiplyPolys should multiply the 2 polynomials and return a

reference to a new linked list containing the resultant polynomial. (18 marks)

Hint: To multiply 2 polynomials multiply each term in the first polynomial by each term in the

second polynomial. Remember that you will need to collect like terms so that there is at most

one node for each exponent in the resultant polynomial.

Total Marks: 100


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp