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

Question:In this exercise we derive an estimate of the average-case complexity of the variant of the bubble sort algorithm that terminates once a pass has been made with no interchanges. Let \(X\) be the random variable on the set of permutations of a set of \(n\) distinct integers \(\left\{ {{a_1},{a_2}, \ldots ,{a_n}} \right\}\) with \({a_1} < {a_2} < \ldots < {a_n}\) such that \(X(P)\) equals the number of comparisons used by the bubble sort to put these integers into increasing order.

(a) Show that, under the assumption that the input is equally likely to be any of the \(n\) ! permutations of these integers, the average number of comparisons used by the bubble sort equals \(E(X)\).

(b)Use Example 5 in Section 3.3 to show that \(E(X) \le \)\(n(n - 1)/2\).

(c) Show that the sort makes at least one comparison for every inversion of two integers in the input.

(d) Let \(I(P)\) be the random variable that equals the number of inversions in the permutation \(P\). Show that \(E(X) \ge E(I)\).

(e) Let \({I_{j,k}}\) be the random variable with \({I_{j,k}}(P) = 1\) if \({a_k}\) precedes \({a_j}\) in \(P\) and \({I_{j,k}} = 0\) otherwise. Show that \(I(P) = \sum\limits_k {\sum\limits_{j < k} {{I_{j,k}}} } (P).\)

(f) Show that \(E(I) = \sum\limits_k {\sum\limits_{j < k} E } \left( {{I_{j,k}}} \right)\).

(g) Show that \(E\left( {{I_{j,k}}} \right) = 1/2\). (Hint: Show that \(E\left( {{I_{j,k}}} \right) = \) probability that \({a_k}\) precedes \({a_j}\) in a permutation \(P\). Then show it is equally likely for \({a_k}\) to precede \({a_j}\) as it is for \({a_j}\) to precede \({a_k}\) in a permutation.)

(h) Use parts (f) and (g) to show that \(E(I) = n(n - 1)/4\).

(i) Conclude from parts (b), (d), and (h) that the average number of comparisons used to sort \(n\) integers is \(\Theta \left( {{n^2}} \right)\).

Short Answer

Expert verified

Answer

(a) \(E(X)\) is equal to the average over all permutations.

(b) The resultant answer is \(E(X) \le \frac{{n(n - 1)}}{2}\).

(c) The inversion of two integers occurs if they are in the wrong order. To determine if the two integers are in the wrong order, we need to compare the two integers.

(d) The resultant answer is \(E(X) \ge E(I)\).

(e) The resultant answer is \(I(P) = \sum\limits_k {\sum\limits_{j < k} {{I_{j,k}}} } (P)\).

(f) The resultant answer is \(E(I) = \sum\limits_k {\sum\limits_{j < k} E } \left( {{I_{j,k}}} \right)\).

(g) The resultant answer is \(E\left( {{I_{j,k}}} \right) = np = \frac{1}{2}\).

(h) The resultant answer is \(E(I) = \frac{{n(n - 1)}}{4}\).

(i) The resultant answer is \(E(X) = \Theta \left( {{n^2}} \right)\).

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

Given data

The given data is a set of \(n\) distinct integers\(\left\{ {{a_1},{a_2}, \ldots ,{a_n}} \right\}\)with \({a_1} < {a_2} < \ldots < {a_n}\).

02

Concept of Bubble sort

Bubble sort interchanges consecutive integers if they are in the wrong order.

The sorting algorithm always moves from the left to the right through the list until the list is entirely sorted. On iteration \(i\) of the algorithm, we know that the last \(i - 1\) elements are in the correct order.

03

Find the probability

(a)

Each of the \(n\) ! permutations are equally likely, thus the probability to select a particular permutation is then 1 chancy in \(n!\)

\(P(X = i) = \frac{1}{{n!}}\); \(i\) represents the \(i - th\) permutation in lexicographic order.

The expected value is the sum of the product of each possibility with its probability \(P(x)\) :

\(\begin{aligned}{c}E(X) &= \sum\limits_{i = 1}^{n!} i P(X = i)\\E(X) &= \sum\limits_{i = 1}^{n!} {\frac{i}{{n!}}} \\E(X) &= \frac{1}{{n!}}\sum\limits_{i = 1}^{n!} i \end{aligned}\)

We then note that the average number of comparisons \(E(X)\) is equal to the average over all permutations.

04

 Step 4: Compare all the iteration

(b)

In the first iteration, \(n - 1\) comparisons are made (as there are \(n - 1\) consecutive pairs of elements).

In the second iteration, \(n - 2\) comparisons are made (as we already know that the last element is in the correct location).

In the third iteration, \(n - 3\) comparisons are made (as we already know that the last two elements are in the correct location).

Thus, in the \(k - th\)iteration, \(n - k\) comparisons are made.

When there are \(n\) elements in the list, then there are \(n - 1\) iterations.

05

Add all counts of comparisons  

We then obtain;

\(\begin{aligned}{l}(n - 1) + (n - 2) + (n - 3) + \ldots + (n - k) + \ldots + 1 &= \sum\limits_{i = 1}^{n - 1} {(n - i)} \\(n - 1) + (n - 2) + (n - 3) + \ldots + (n - k) + \ldots + 1 &= \sum\limits_{i = 1}^{n - 1} n - \sum\limits_{i = 1}^{n - 1} i \end{aligned}\)

Using \(\sum\limits_{k = 1}^n k = \frac{{n(n + 1)}}{2}\)

\(\sum\limits_{k = 1}^n k = n \cdot \sum\limits_{i = 1}^{n - 1} 1 - \frac{{(n - 1)n}}{2}\)

Using \(\sum\limits_{k = 1}^n 1 = n\)

\(\begin{aligned}{l}\sum\limits_{k = 1}^n 1 = n \cdot n - \frac{{(n - 1)n}}{2}\\\sum\limits_{k = 1}^n 1 = {n^2} - \frac{{{n^2} - n}}{2}\\\sum\limits_{k = 1}^n 1 = {n^2} - \frac{1}{2}{n^2} - \frac{1}{2}n\\\sum\limits_{k = 1}^n 1 = \frac{1}{2}{n^2} - \frac{1}{2}n\\\sum\limits_{k = 1}^n 1 = \frac{{n(n - 1)}}{2}\end{aligned}\)

Thus, the total number of comparisons is \(\frac{{n(n - 1)}}{2}\). Since the average number of comparisons is always smaller than or equal to the total number of comparisons:

\(E(X) \le \frac{{n(n - 1)}}{2}\).

06

Compare the integers

(c)

The inversion of two integers occurs if they are in the wrong order. To determine if the two integers are in the wrong order, we need to compare the two integers and thus at least one comparison is made for every inversion of two integers in the input.

07

Compare and find the probability

(d)

\(I(P) = \)Number of inversions in the permutation \(P\).

\(X(P) = \)number of comparisons in the permutation \(P\).

By part (c), we know that at least one comparison is made for every inversion: \(X(P) \ge I(P)\) for every permutation \(P\)

The expected value is the sum of the product of each possibility \(x\) with its probability \(P(x)\) :

\(\begin{aligned}{l}E(X) &= \sum\limits_P X (P)P(X = P)\\E(X) \ge \sum\limits_P I (P)P(X = P)\\E(X) &= E(I)\end{aligned}\)

Thus, we have then shown \(E(X) \ge E(I)\).

08

Simplify the expression

(e)

Simplify;

\({I_{j,k}}(P) = 1\)if \({a_k}\) precedes \({a_j}\) in \(P\)

\({I_{j,k}}(P) = 0\)otherwise

The inversion of two integers occurs if they are in the wrong order and thus if \({a_k}\) precedes \({a_j}\) when \(j < k\).

The number of inversions is then equal to the number of values for \(k\) and \(j\) (with \(j < k\) ) such that \({a_k}\) precedes \({a_j}\), thus the number of inversions is then also equal to the sum of the values \({I_{j,k}}(P) = 1\) for \(k\) and \(j\) (with \(j < k\)) (Note that if \({a_k}\) does not precede \({a_j}\) then \({I_{j,k}}(P) = 0\) and thus this values would not affect the number of inversions).

\(I(P) = \sum\limits_k {\sum\limits_{j < k} {{I_{j,k}}} } (P)\).

09

Find the probability \(P(x)\)

(f)

The expected value is the sum of the product of each possibility \(x\) with its probability \(P(x)\) :

\(\begin{aligned}{l}E(I) &= \sum\limits_P I (P)P(X = P)\\E(I) &= \sum\limits_P {\sum\limits_k {\sum\limits_{j < k} {{I_{j,k}}} } } (P)P(X = P)\quad {\rm{ By part (e)}}\\E(I) &= \sum\limits_k {\sum\limits_{j < k} {\left( {\sum\limits_P {{I_{j,k}}} (P)P(X = P)} \right)} } \\E(I) &= \sum\limits_k {\sum\limits_{j < k} E } \left( {{I_{j,k}}} \right)\end{aligned}\).

10

Simplify the expression

(g)

\({a_j}\)is equally likely to precede \({a_k}\) as it is for \({a_k}\) to precede \({a_j}\), thus we then have 1 chance in 2 that \({I_{j,k}}(P) = 1\).

\(p = \frac{1}{2}\)

\({I_{j,k}}\)then represents 1 Bernoulli trial with a constant probability of success of \(p = \frac{1}{2}\)

\(n = 1\)

The expected number of successes among a fixed number \(n\) of mutually independent Bernoulli trials is \(np\), with \(p\) the constant probability of success.

\(\begin{aligned}{l}E\left( {{I_{j,k}}} \right) &= np\\E\left( {{I_{j,k}}} \right) &= 1 \cdot \frac{1}{2}\\E\left( {{I_{j,k}}} \right) &= \frac{1}{2}\end{aligned}\).

11

Use the part (f) and (g) to simplify the expression

(h)

Let us assume that the permutation \(P\) contains \(n\) distinct integers.

Use the result of part (f) and (g):

\(\begin{aligned}{l}E(I) &= \sum\limits_k {\sum\limits_{j < k} E } \left( {{I_{j,k}}} \right)\\E(I) &= \sum\limits_k {\sum\limits_{j < k} {\frac{1}{2}} } \\E(I) &= \sum\limits_{k = 1}^n {\sum\limits_{j = 1}^{k - 1} {\frac{1}{2}} } \\E(I) &= \sum\limits_{k = 1}^n {\frac{{k - 1}}{2}} \end{aligned}\)

Similarly,

\(\begin{aligned}{l}E(I) &= \sum\limits_{k = 1}^n {\frac{k}{2}} - \sum\limits_{k = 1}^n {\frac{1}{2}} \\E(I) &= \frac{1}{2}\sum\limits_{k = 1}^n k - \sum\limits_{k = 1}^n {\frac{1}{2}} \\E(I) &= \frac{1}{2} \cdot \frac{{n(n + 1)}}{2} - \sum\limits_{k = 1}^n {\frac{1}{2}} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} \sum\limits_{k = 1}^n k &= \frac{{n(n + 1)}}{2}\\E(I) &= \frac{{n(n + 1)}}{4} - \frac{n}{2}{\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} {\kern 1pt} \sum\limits_{k = 1}^n a = an\end{aligned}\)

Similarly,

\(\begin{aligned}{c}E(I) &= \frac{{{n^2} + n}}{4} - \frac{{2n}}{4}\\E(I) &= \frac{{{n^2} + n - 2n}}{4}\\E(I) &= \frac{{{n^2} - n}}{4}\\E(I) &= \frac{{n(n - 1)}}{4}\end{aligned}\).

12

Combine the equations

(i)

Result of part (b):

\(E(X) \le \frac{{n(n - 1)}}{2} = \frac{1}{2}{n^2} - \frac{1}{2}n\)

Results of part (d) and (h):

\(\begin{aligned}{l}E(X) \ge E(I) &= \frac{{n(n - 1)}}{4}\\E(X) \ge E(I) &= \frac{1}{4}{n^2} - \frac{1}{4}n\end{aligned}\)

Combine the information, we then obtain: \(\frac{1}{4}{n^2} - \frac{1}{4}n \le E(X) \le \frac{1}{2}{n^2} - \frac{1}{2}n\)

And thus: \(\Theta \left( {{n^2}} \right) \le E(X) \le \Theta \left( {{n^2}} \right)\)or equivalently: \(E(X) = \Theta \left( {{n^2}} \right)\).

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free