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

Devise an efficient algorithm for finding the second

largest element in a sequence of n elements and deter-mine the worst-case

complexity of your algorithm.

Short Answer

Expert verified

Procedure second largest (a1,a2,....anintegers withn2 )

temp=false

j:=2

whilejn-1 and temp=false

ifa1aj then temp=true elsej=j+1

ifa1<aj

max:=ajmin=a1

else

max=a1min=aj

forj=j+1 ton

ifaj>max then

second:=ai

return second

Worst-case complexity :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

Algorithm

Let us call the algorithm second largest and the input of the algorithm is a list of integersa1,a2,....an

Procedure second largesta1,a2,....an (integers withn2 )

we first determine the first two different element ( if no two different element exit then the repeated number will be returned)

temp=false

j:=2

whilejn-1 and temp=false

ifa1aj then temp=true elsej=j+1

the variable “max” will keep track of the largest number and the variable

“second” will keep track of the position of the second largest number. We initially define” max” as the largest of the first two different elements and the second as the smallest of the two different elements

02

Algorithm

ifa1<aj then

max=a1

min=a1

else

max=a1

min=aj

Next we compare every(other)element In the list with the current largedt number

if the element is larger then the current largest number then we replace the “max” by this element and we replace the second by “max”

if the element is large then current than the second largest number but smaller then the largest number then we replace the “max” by this elements and we replace the second by “max”

03

Algorithm

forj=j+1 ton

fai>maxsecond:=maxmax=ai

ifmax>ai>second

second=ai

Finally we return the second largest number

04

Algorithm 

Return second

whilejn-1 and temp=false

ifa1aj then temp=true elsej=j+1

ifa1<aj

max:=aj

min=a1

else

max=a1

min=aj

forj=j+1 ton

ifaj>max then

max>ai>secondsecond=ai

Return second

05

Algorithm

The while loop will have at mostn-2 iteration while the for-loops at mostn-2 iteration as well

since n-2 is O(n) both loops have a worst-case complexity O(n)

since the while-loop and for-loop are not nested and both have a worst-case complexity of O(n)the worst case complexity of the entire algorithm is also 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