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

Describe how the number of comparisons used in the worst case changes when the size of the list to be stored doubles from n to 2n , where n is a positive integer when these sorting algorithms are used.

  1. bubble sort.
  2. insertion sort.
  3. selection sort (described in the preamble to Exercise 41 to Section 3.1).
  4. binary insertion sort (described in the preamble to Exercise 47 in Section 3.1 )

Ann×n matrix is called upper triangular ifrole="math" localid="1668661913863" aij=0 whenever i >j .

Short Answer

Expert verified
  1. Number of comparisons change from n2n2to2n2n.
  2. Number of comparisons change fromn2n2to2n2n.
  3. Number of comparisons change fromn2n2to2n2n.
  4. Number of comparisons increase by i=n2n1log2i.

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

(a)Step 1: Bubble sort

Bubble sort successively compares two adjacent elements and sorts them if they are in decreasing order (since we want to resort the list in increasing order).

Let the list contain n elements.

First pass- We compare all n - 1 pairs of adjacent elements and thus we make n - 1 comparisons.

Second pass- We compare n - 2 pairs of adjacent elements (excluding the first element) and thus we make n - 2 comparisons.

Third pass- We compare n - 3 pairs of adjacent elements (excluding the first two elements) and thus we make n - 3 comparisons.

The bubble sort algorithm will stop if we made comparison in some pass (which will be the last pass). If the original list contains n elements, the bubble sort algorithm will then stop when the pass.

#comparisons=(n1)+(n2)+(n3)++1=i=1n1i

If we would then have a list ofelements instead, then we would make

(2n)22n2=4n22n2=2n2ncomparisons.

We then note that the number of comparisons more than doubled and less than quadruples when the size of the list is increased from n to 2n .

02

(b)Step 2: insertion sort

Insertion sort compares first the second element with the first and correctly sorts these two numbers. Then it takes the next element and correctly inserts it in the part of the string that we already know is correctly sorted, and so on.

First pass-We compare the first two elements and thus we make 1 comparison.

Second pass-We compare the third element with the first two elements, thus we make 1 comparisons.

Third pass-We compare the forth element with the first three elements, thus we make 3 comparisons.

kth pass-On the kth pass, we compare the k + 1 element with the first k terms and thus we make k comparisons.

The insertion algorithm will stop if only 1 element is remaining. If the original list contains n elements, the insertion algorithm will then stop when the n - 1 th pass (when the nth element is compared with the first n - 1 terms).

\#comparisons=1+2+3++(n1)=i=1n1i

sincei=1n=n(n+1)2

\#comparisons=1+2+3++(n1)=i=1n-1==n(n+1)2=n2n2

If we would then have a list ofelements instead, then we would make

(2n)22n2=4n22n2=2n2ncomparisons.

We then note that the number of comparisons more than doubled and less than quadruples when the size of the list is increased from n to data-custom-editor="chemistry" (2n)22n2=4n22n2=2n2n.

03

(c)Step 3: Selection sort

Selection sort first determines the minimum in the sequence and place this value at the front of the sequence. Then the algorithm determines the minimum of the remaining terms (thus ignoring the terms that we know are already in the correct position), this minimum is then placed in the second position of the sequence, and so on.

Let the list contain n elements.

First pass- We need to make n -1 comparisons to determine the minimum of the list of n elements.

Second pass- We need to make n -2 comparisons to determine the minimum of the remaining list of n -1 elements.

Third pass- We need to make n - 3 comparisons to determine the minimum of the remaining list of n -2 elements.

The selection sort algorithm will stop if we made 1 comparison in some pass (which will be the last pass). If the original list contains n elements, the selection algorithm will then stop when the n -1 th pass.

\#comparisons=(n1)+(n2)+(n3)+.+1=i=1n1i.

Sincei=1ni=n(n+1)2

#comparisons=(n1)+(n2)+(n3)+.+1=i=1n1i=(n1)n2=n2n2

If we would then have a list of elements instead, then we would make (2n)22n2=4n22n2=2n2ncomparisons.

We then note that the number of comparisons more than doubled and less than quadruples when the size of the list is increased from n to 2n .

04

(d)Step 4: Binary Insertion sort

Binary insertion sort first compares the second value with the first and inserts the second value as appropriate. On each consecutive pass, the next value is compared with the middle of the already sorted list (if even numbered, then the lower value in the middle is chosen) and determined in which sub interval the value lies, until we have found the position where the value should be inserted and then the value is inserted in the correct spot.

Let the list contain n elements.

First pass- We compare the first two elements and thus we make 1 comparison.

Second pass- We compare the third element with the first two elements in worst case scenario, thus we make 2 comparisons.

Third pass- We compare the forth element with the first the second element and the first or third element, thus we make 2 comparisons.

kth pass- On the kth pass, we compare the k + 1 element with the log2kelements and thus we make log2kcomparisons.

The binary insertion algorithm will stop if only 1 element is remaining. If the original list contains n elements, the binary insertion algorithm will then stop when the n - 1 th pass.

\#comparisons=1+2+2+.+log2k+log2(n1)=i=1n1log2i

Thus, we make at mosti=1n1log2icomparisons when the list contains n elements.

If we could then have a list of 2n elements instead, then we would make at mosti=1n1log2icomparisons.

i=12n1log2ii=1n1log2i=i=12n1log2i

We then note that the number of comparisons increase by i=1n1log2i, when the size of the list is increased from n to 2n .

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