Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

The conventional algorithm for evaluating a polynomial

\({a_n}{x^n} + {a_n}_{ - 1}{x^n}^{ - 1} + ... + {a_1}x + {a_0}\)at \(x = c\) can be expressed in pseudocode by

procedure \(polynomial\) (\(c,{\rm{ }}{a_0},{\rm{ }}{a_1},{\rm{ }} \ldots ,{\rm{ }}{a_n}:\) real numbers)

\(\begin{array}{*{20}{l}}{power: = 1}\\{y: = {a_0}}\end{array}\)

\(\begin{array}{l}\begin{array}{*{20}{l}}{{\bf{for}}{\rm{ }}i: = 1{\rm{ }}to{\rm{ }}n}\\{\;\;\;\;power: = power*c}\\{\;\;\;\;y: = y + {a_i}*power}\end{array}\\{\bf{return}}{\rm{ }}y{\rm{ }}\{ y = {a_n}{c^n} + {a_{n - 1}}{c^n}^{ - 1} + ... + {a_1}c + {a_0}\} \end{array}\)

where the final value of y is the value of the polynomial at \(x = c\).

a) Evaluate \(3{x^2} + x + 1\) at \(x = 2\) by working through each step of the algorithm showing the values assigned at each assignment step.

b) Exactly how many multiplications and additions are used to evaluate a polynomial of degree \(n\) at \(x = c\)? (Do not count additions used to increment the loop variable).

Short Answer

Expert verified

(a) The value of \(3{x^2} + x + 1\) at \(x = 2\) is 15.

(b) There is exactly \(2n\) multiplications and \(n\) additions used to evaluate a polynomial of degree \(n\) at \(x = c\).

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

(a)Step 1: Given algorithm

procedure\(polynomial\)(\(c,{\rm{ }}{a_0},{\rm{ }}{a_1},{\rm{ }} \ldots ,{\rm{ }}{a_n}:\)real numbers)

\(\begin{array}{*{20}{l}}{power: = 1}\\{y: = {a_0}}\end{array}\)

\(\begin{array}{l}\begin{array}{*{20}{l}}{{\bf{for}}{\rm{ }}i: = 1{\rm{ }}to{\rm{ }}n}\\{\;\;\;\;power: = power*c}\\{\;\;\;\;y: = y + {a_i}*power}\end{array}\\{\bf{return}}{\rm{ }}y{\rm{ }}\{ y = {a_n}{c^n} + {a_{n - 1}}{c^n}^{ - 1} + ... + {a_1}c + {a_0}\} \end{array}\)

02

Evaluating the value of \(y\):

Initially, consider the values as,

\(\begin{array}{*{20}{l}}{power = 1}\\{y = {a_0} = 1}\end{array}\)

First iteration:\(i = 1\)

Then,

\(\begin{array}{l}power = powe{r_{old}}.c\\{\rm{ }} = 2\\{\rm{ y = }}{{\rm{y}}_{{\rm{old}}}}{\rm{ + }}{{\rm{a}}_{\rm{1}}}{\rm{.power}}\\{\rm{ = 3}}\end{array}\)

Second iteration:\(i = 2\)

The algorithm returns\(y = 15\)

Thus, the value of \(3{x^2} + x + 1\) at \(x = 2\) is 15.

03

(b)Step 3: Given algorithm

procedure\(polynomial\)(\(c,{\rm{ }}{a_0},{\rm{ }}{a_1},{\rm{ }} \ldots ,{\rm{ }}{a_n}:\)real numbers)

\(\begin{array}{*{20}{l}}{power: = 1}\\{y: = {a_0}}\end{array}\)

\(\begin{array}{l}\begin{array}{*{20}{l}}{{\bf{for}}{\rm{ }}i: = 1{\rm{ }}to{\rm{ }}n}\\{\;\;\;\;power: = power*c}\\{\;\;\;\;y: = y + {a_i}*power}\end{array}\\{\bf{return}}{\rm{ }}y{\rm{ }}\{ y = {a_n}{c^n} + {a_{n - 1}}{c^n}^{ - 1} + ... + {a_1}c + {a_0}\} \end{array}\)

04

Evaluating the number of multiplications

The algorithms only make multiplications or additions in a line

There are 2 multiplications and 1 addition per iteration of the for loop

The total number of multiplication or addition is then the product of the number of the values for\(i\)and the number of multiplications/additions in each iteration of\(i\):

Number of multiplications\( = 2n\)

Number of additions\( = n\)

Thus, \(2n\) multiplications and \(n\) additions are used to evaluate a polynomial of degree \(n\) at \(x = c\).

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free