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) Describe an algorithm for finding the first and second largest elements in a list of integers.

b) Estimate the number of comparisons used.

Short Answer

Expert verified

(a) procedure last largest (a1,a2,an:integerswithn3)

if a1<a2 then

max:=a2

next=a1

else

max:=a1

next:=a2

for i:=3 to n

ifaimax then

next:=max

max:=ai

else if nextai<maxthen

next:=ai

returnlast,next

(b)2n-1,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

Step 1

  1. $\ text {\color{\# 4257 b 2} Let us call the algorithm "two largest" and the input of

the algorithm is a list of integers a1,a2,,an \color\{default }

\ \

\ textbf\{procedure \}two largest (a1,a2,anintegers with n3)

\ \

\color{4257b2}The variable “max” will keep track of the largest number, while “next”

Will keep track of the second largest number. We initially define the first two

elements in the list as these two variables (largest of the two is “max” , while

smallest is “next”, if equal, then both values are set to the values).\color{default}

\ \

\textbf{if} a1<a2\textbf{then}

max:=a2

next:=a1

\textbf{else}

max:=a1

next:=a2

\ \

\color{#4257b2}Next we compare every ( other) element in the list with the current

Largest number. if the element is larger than or equal to the current largest

number, then we replace the maximum by this element and we move the old

maximum to second largest element\

Next, we also determine if the element if between the second largest and the

Largest element(up to now ). If this is the case, then we replace the second highest

element by this new element\color{default}

\ \

\textbf{for}i=3\textbf{to}n

\textbf{if}$a_i\geq$max\textbf{then}

next:=a2

max:=a1

\textbf{else if} nextai<max\textbf{then}

next:=a1

\ \

\color{#4257b2} Finally, we return the position of the two largest

numbers.\color|{default}

\ \

\textbf{return } last, next}$

02

Step 2

Combining these steps, we then obtain the algorithm: Procedure last largest

(a1,a2,an:integerswithn3)

If a1<a2then

max:=a2

next:=a1

else

max:=a1

next:=a2

for i:=3 to n

if aimax then

next:=max

max:=ai

else if nextai<maxthen

next:=ai

returnlast,next

03

Step 3

  1. We note that the algorithm initially makes 1 comparison to check a1<a2 .

Next, the algorithm makes at most two comparison ( aimaxand nextai<max)

In every iteration of the for –loop. Since i ranges from 3ton, there are

n-3+1=n-2 iteration of the for –loop and thus there are 2(n-1) comparison in

for –loop.

We then note that there are 2(n-1)+1=2n-2+1=2n-1comparison in total, while

2n-1isO(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