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) Devise a more efficient algorithm for solving the problem described in Exercise 29 that first sorts the input sequence and then checks for each pair of terms whether their difference is in the sequence.

b) Give a big-O estimate for the complexity of this algorithm. Is it more efficient than the brute-force algorithm from Exercise 29?

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)No

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 n 2)

Next, we sort the sequence of the numbers using some sorting algorithm. We determine each triple of elements xi,xj, xk with xi<xj<xk and check whether the sum of one pairs 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.

X1, x2,…,xn:=sort(x1,x2,…xn)

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:

  1. Using an optimal sort algorithm, the worst-case time complexity of the sorting is O (n log n).

We note that we make one comparision ai+aj=ak per iteration of the inner for-loop. i can take on integer values from i to n, while j can take on integer values from i+1 to n, and k can take on integer values from j+1 to n.

Number of comparisions

=i=1nj=i+1nk=j+1n1=i=1nj=i+1n(nj)=i=1nj=i+1nnj=i+1nj=i=1nn(ni)j=1nj+j=1nj=i=1nn(ni)n(n+1)2+i(i+1)2=i=1n(ni)(ni1)2=16n312n2+13

Since, 16n312n2+13 is O(n3) , we then note that the worst-case time complexity is still O(n3) and thus it is not more efficient than the brute force algorithm.

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