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

How many comparisons does the selection sort (see preamble to Exercise 41 in Section 3.1 ) use to sort n items? Use your answer to give a big-O estimate of the complexity of the selection sort in terms of number of comparisons for the selection sort.

Short Answer

Expert verified

On2

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

Selection sort first finds the smallest element in the list and moves the element to the front of the list, then it finds the smallest element in the remaining list and moves the element into the second position, and so on.

Result previous exercise:

Procedure selection sort (a1,a2,...an:naturalnumberswithn2).

for i:=1ton-1

min:=ai

for

j:=i+1tonifaj<minthen

min:=ajk:=j

for m:=itok-1

ak-m+1:=ak-mai:=min

return a1,a2,...an.

02

Solution

The algorithm makes 1 comparison in each iteration of the for-loop (aj<min).

Sinceican take on the values from 1 to n - 1 , i can take on n - 1 values and thus there are n - 1 iterations of the first for-loop.

Since j can take on the values from i + 1 to n, j can take on n - 1 values and thus there are at most n - 1 iterations of the second for-loop.

The number of comparisons is then the product of the number of iterations and the number of comparisons per iteration per loop (Note: product since the loops are nested).

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

Thus n2-2n+1comparisons are made and n2-2n+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