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

Prove that the algorithm you devised in Exercise 17 is correct.

Short Answer

Expert verified

The recursive algorithm is proved.

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

Consider the recursive algorithm

The recursive algorithm is,

procedure product (x,y : nonnegative integers)

return 0

else if

y is even then

return 2. product (x, y / 2)

else return 2. prodcut (x, (y - 1) / 2) + x

02

 Step 2: Prove that the algorithm obtained in Exercise 17 is correct

This can be proved by Strong Induction.

Take y = 0.

The algorithm returns 0, while the product of a nonnegative integer x and 0 is x . 0 = 0 . Thus, the algorithm is correct for the basis step.

Assume that the algorithm is correct for all nonnegative integers up to k with k > 0 .

product (x, i) = x. i (when i < k)

It is required to prove that the algorithm is also correct for k + 1.

k+1even product(x,k+1)=2product(x,(k+1)/2)=2x(k+1)2=x(k+1)

And,

k+1odd product(x,k+1)=2product(x,[(k+1)/2])+x=2xk2+x=xk+x=x(k+1)

It is observed that the algorithm gives the product and thus the algorithm is correct for the nonnegative integer k + 1.

Hence, by the principle of strong induction, the recursive algorithm is correct.

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