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 worst-case time complexity of the algorithm you devised in Exercise 30 of Section 3.1 for locating all modes in a list of nondecreasing integers.

Short Answer

Expert verified

O(n)

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 modes (a1,a2,...an:integerswithn1anda1a2...an)

j:=1S:=

for i:=1ton

count(ai):=1

for k:=2ton

if ak=a(k-1)thencount(ak):=count(ak-1)+1

if count(ak)>jthen

j:=count(ak)

for m:=1ton

if count(am)=j then role="math" localid="1668624593950" S:=Sam

return S.

02

Prove

The algorithm makes 2 comparisons in each iteration of the second for-loop of k (if ak=ak-1andifcount(ak)>j).

Since k can take on the values from role="math" localid="1668624785271" 2ton(fork:=2ton), k can take on values and thus there are n - 1 iterations in the second for-loop.

The algorithm makes 1 comparison in each iteration of the third for-loop of m(if count(am)=j).).

Since m can take on the values from to n (for to n), m can take on n values and thus there are n iterations in the third for-loop.

The number of comparisons is then the sum of the product of the number of iterations and the number of comparisons per iteration for each loop (Note: We take the sum, because the two for-loops are not nested):

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

Thus 3n-2comparisons are made and 3n-2 is O(n).

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