Database System Concepts
Database System Concepts
7th Edition
ISBN: 9780078022159
Author: Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher: McGraw-Hill Education
Bartleby Related Questions Icon

Related questions

Question

I need this answer in Haskell Programming language only.

4. Write a function that adds two polynomials. Ensure that the polynomial produced matches the requirements.

addPoly :: (Num a, Eq a) => Poly a -> Poly a -> Poly a

For example:

> addPoly (P [1]) (P [-1,1])
P [0,1]
> addPoly (P [17]) (P [0,0,0,1])
P [17,0,0,1]
>addPoly (P [1,-1]) (P [0,1])
P [1]

You may find it helpful to write addPoly using two helper functions: one to combine the lists of coefficients, and one to trim trailing zeroes.

Your implementation of addPoly should have this property: addPoly p q $$ x == (p $$ x) + (q $$ x)

### Adding Polynomials in Haskell

Write a function that adds two polynomials. Ensure that the polynomial produced matches the requirements.

```haskell
addPoly :: (Num a, Eq a) => Poly a -> Poly a -> Poly a
```

#### For example:

```haskell
> addPoly (P [1]) (P [-1,1])
P [0,1]

> addPoly (P [17]) (P [0,0,0,1])
P [17,0,0,1]

> addPoly (P [1,-1]) (P [0,1])
P [1]
```

You may find it helpful to write `addPoly` using two helper functions: one to combine the lists of coefficients, and one to trim trailing zeroes.

Your implementation of `addPoly` should have this property:

```haskell
addPoly p q $$ x == (p $$ x) + (q $$ x)
```
expand button
Transcribed Image Text:### Adding Polynomials in Haskell Write a function that adds two polynomials. Ensure that the polynomial produced matches the requirements. ```haskell addPoly :: (Num a, Eq a) => Poly a -> Poly a -> Poly a ``` #### For example: ```haskell > addPoly (P [1]) (P [-1,1]) P [0,1] > addPoly (P [17]) (P [0,0,0,1]) P [17,0,0,1] > addPoly (P [1,-1]) (P [0,1]) P [1] ``` You may find it helpful to write `addPoly` using two helper functions: one to combine the lists of coefficients, and one to trim trailing zeroes. Your implementation of `addPoly` should have this property: ```haskell addPoly p q $$ x == (p $$ x) + (q $$ x) ```
Expert Solution
Check Mark
Knowledge Booster
Background pattern image
Similar questions
Recommended textbooks for you
Text book image
Database System Concepts
Computer Science
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:McGraw-Hill Education
Text book image
Starting Out with Python (4th Edition)
Computer Science
ISBN:9780134444321
Author:Tony Gaddis
Publisher:PEARSON
Text book image
Digital Fundamentals (11th Edition)
Computer Science
ISBN:9780132737968
Author:Thomas L. Floyd
Publisher:PEARSON
Text book image
C How to Program (8th Edition)
Computer Science
ISBN:9780133976892
Author:Paul J. Deitel, Harvey Deitel
Publisher:PEARSON
Text book image
Database Systems: Design, Implementation, & Manag...
Computer Science
ISBN:9781337627900
Author:Carlos Coronel, Steven Morris
Publisher:Cengage Learning
Text book image
Programmable Logic Controllers
Computer Science
ISBN:9780073373843
Author:Frank D. Petruzella
Publisher:McGraw-Hill Education