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

a) Use pseudocode to specify a brute-force algorithm that determines when given as input a sequence of n positive integers whether there are two distinct terms of the sequence that have as sum a third term. The algorithm should loop through all triples of terms of the sequence, checking whether the sum of the first two terms equals the third.

b) Give a big-O estimate for the complexity of the bruteforce algorithm from part (a).

Short Answer

Expert verified

(a)

Procedure triplesum(x1,x2,…,xn:numbers with n2)

For i:=1 to n

For j:=i+1 to n

For k:=1 to n

If (xi + xj= xk) then

Return true

Return false

(b) O(n3)

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

DEFINITIONS

(a) We call the algorithm “triplesum” and the input of the algorithm is a sequence of n numbers x1,x2,…,xn.

Procedure triplesum (x1,x2,..xn:numbers with n2)

Next we determine each triple of elements xi,xj,xk and check whether the sum of one pair is equal to the third element. If we find such a triple then the algorithm needs to return true. Otherwise the algorithm will need to return false.

For i:=1 to n

For j:=i+1 to n

For k:=1 to n

If (xi + xj = xk) then

Return true

Return false

02

Step 2:

Combining these steps we then obtain the algorithm: procedure triplesum (x1,x2,..,xn:numbers with n 2)

For i:=1 to n

For j:=i+1 to n

For k:=1 to n

If (xi + xj= xk) then

Return true

03

Step 3:

(b) We note that we make one comparision xi+xj=xk per iteration of the inner for-loop

Since we have at most n iterations of each of the three for-loops, which imolies that we then make at most n.n.n = n3 comparisions xi+xj = xk in the algorithm and thus the complexity of the algorithm is O(n3).

One App. One Place for Learning.

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

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free