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

Find a big-O estimate for the worst-case complexity in terms of number of comparisons used and the number of terms swapped by the binary insertion sort described in the preamble to Exercise47 in Section3.1 .

Short Answer

Expert verified

O(n log 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

Result previous exercise:

Procedure: binary insertion sort (a1,a2,...an:integerswithn1)

fork:=2ton

i:=1j:=k

while i < j

m:=(i+j)/2ifak>amtheni:=m+1elsej:=m

if akaithen

temp:=ak

forp:=0tok-i-1

ak-p:=ak-p-1ai:=temp

return a1,a2,...an.

02

Step 2

SOLUTION

The algorithm makes 2 comparison in each iteration of the while-loop and makes 1 additional comparisons for each iteration of the for-loop.

The number of iterations of the while-loop is the number of times we divide the sub list of k integers into 2 lists. Ifk=2m, then this means that the while-loop hasm=log2kiterations. If2m-1<k<2m, then the while-loop has iterations. Since log2kwhen log2kis an integer, there are m=log2kiterations of the while-loop.

The number of comparisons is the product of the number of iterations and the number of comparisons per iteration.

Number of comparisons in while-loop =k=2n2log2k+1

=2k=2nlog2k+(n1)2k=2nlog2n+(n1)=2(n1)log2n+(n1)=2nlog2n2log2n+n1

Thus at most 2nlog2n-2log2n+n-1comparisons are made and 2nlog2n-2log2n+n-1is O(nlogn).

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