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

Analyze the worse-case time complexity of the algorithm you devised in Exercise 31 of Section 3.1 for finding the first term of a sequence of integers equal to some previous term.

Short Answer

Expert verified

O(n2)

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

Write Algorithm

Result previous exercise:

Procedure first repeated (a1,a2,...an:integerswithn1)

location:=0i:=2

while inandlocation=0

j:=1

while j<iandlocation=0

if ai=ajthenlocation:=i

else i:=i+1

return location.

02

Solution

In worst-case scenario, the match is the last number in the list and thus the while-loop will end for the last value n ofi.

The algorithm makes 2 comparisons in each iteration of the first while-loop(in,location=0)

The algorithm makes comparisons in each iteration of the second while-loop (j<i,location=0,ai=aj).

Since I can take on the values from 2 to n, I can take on n - 1 values and thus there are n - 1 iterations in the first while-loop.

Since j can take on the values from 1 to n - 1 , j can take on n - 1 values and thus there are n - 1 iterations in the second while-loop.

The number of comparisons is then the product of the number of iterations and the number of comparisons per iteration for each loop. (Note: We use the product, because the while-loops are nested).

Number of comparisons =2(n-1)+3(n-1)(n-1)

=2(n1)+3(n1)2=3n24n+1

Thus 3n2-4n+1 comparisons are made and 3n2-4n+1isO(n2).

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