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

a) Describe the merge sort algorithm.

b) Use the merge sort algorithm to put the list \(4,\,10,\,\,1,\,\,5,\,\,3,\,\,8,\,\,7,\,\,2,\,\,6,\,\,9\) in increasing order.

c) Give a big-Oestimate for the number of comparisons used by the merge sort.

Short Answer

Expert verified
  1. A merge sort algorithm is a sorting algorithm that sorts a list by splitting the list in two, sorting each of the two resulting lists, and merging the results into a sorted list.
  1. The list in increasing order using the merge sort algorithm is

\(1,\,\,2,\,\,3,\,\,4,\,\,5,\,\,6,\,\,7,\,\,8,\,\;9,\;10\)

  1. big-O estimate for the number of comparisons used by the merge sort is \(O\left( {10\log 10} \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

Defining the Algorithm and Theorem 1

Algorithm are the guidelines or the step by step procedure that are followed to perform the calculations, solving specific tasks, reasoning in computer based applications

Theorem 1:

The number of comparisons needed to merge sort a list with nelements is\(O\left( {nlogn} \right)\).

02

Step 2:(a) Defining the merge sort algorithm

A merge sort algorithm is a sorting algorithm that sorts a list by splitting the list in two, sorting each of the two resulting lists, and merging the results into a sorted list.

03

Step 3:(b) Using the merge sort algorithm to put the list \(4,\,10,\,\,1,\,\,5,\,\,3,\,\,8,\,\,7,\,\,2,\,\,6,\,\,9\) in increasing order.

A merge sort starts by splitting the list into individual elements by successively

splitting lists in two.

\(\begin{array}{l}mergesort\left( {4,\,10,\,\,1,\,\,5,\,\,3,\,\,8,\,\,7,\,\,2,\,\,6,\,\,9} \right) = mergesort\left( {4,\,10,\,\,1,\,\,5,\,\,3} \right),mergesort\left( {8,\,\,7,\,\,2,\,\,6,\,\,9} \right)\\mergesort\left( {4,\,10,\,\,1,\,\,5,\,\,3} \right) = mergesort\left( {4,\,10,\,\,1} \right),mergesort\left( {\,5,\,\,3} \right)\\mergesort\left( {8,\,\,7,\,\,2,\,\,6,\,\,9} \right) = mergesort\left( {8,\,\,7,\,\,2} \right),mergesort\left( {6,\,\,9} \right)\\mergesort\left( {4,\,10,\,\,1} \right) = mergesort\left( {4,\,10} \right),mergesort\left( 1 \right)\end{array}\)\(\begin{array}{l}mergesort\left( {8,\,\,7,\,\,2} \right) = mergesort\left( {8,\,\,7} \right)mergesort\left( 2 \right)\\mergesort\left( {\,5,\,\,3} \right) = mergesort\left( {\,5} \right),mergesort\left( {\,\,3} \right)\\mergesort\left( {6,\,\,9} \right) = mergesort\left( 6 \right),mergesort\left( {\,9} \right)\\mergesort\left( {4,\,10} \right) = mergesort\left( 4 \right),mergesort\left( {10} \right)\\mergesort\left( {8,\,\,7} \right) = mergesort\left( 8 \right),mergesort\left( {\,7} \right)\end{array}\)

Now proceed backward as:

\(\begin{array}{l}mergesort\left( {8,\,\,7} \right) = merge\left( {8,\,\,7} \right) = 7,8\\mergesort\left( {4,\,10} \right) = merge\left( {4,\,10} \right) = 4,10\\mergesort\left( {6,\,\,9} \right) = merge\left( {6,\,\,9} \right) = 6,9\\mergesort\left( {\,5,\,\,3} \right) = merge\left( {\,5,\,\,3} \right) = 3,5\end{array}\)

\(\begin{array}{c}mergesort\left( {8,\,\,7,\,\,2} \right) = merge\left( {mergesort\left( {8,\,\,7} \right),mergesort\left( 2 \right)} \right)\\ = merge\left( {7,8,2} \right)\\ = 2,7,8\end{array}\)

\(\begin{array}{c}mergesort\left( {4,\,\,10,\,\,1} \right) = merge\left( {mergesort\left( {4,\,\,10} \right),mergesort\left( 1 \right)} \right)\\ = merge\left( {4,10,1} \right)\\ = 1,4,10\end{array}\)

\(\begin{array}{c}mergesort\left( {8,\,\,7,\,\,2,\,\,6,\,\,9} \right) = merge\left( {mergesort\left( {8,\,\,7,\,\,2} \right),mergesort\left( {6,\,\,9} \right)} \right)\\ = merge\left( {2,7,8,6,9} \right)\\ = 2,6,7,8,9\end{array}\)

\(\begin{array}{c}mergesort\left( {4,\,10,\,\,1,\,\,5,\,\,3} \right) = merge\left( {mergesort\left( {4,\,10,\,\,1} \right),mergesort\left( {\,5,\,\,3} \right)} \right)\\ = merge\left( {1,4,10,3,5} \right)\\ = 1,3,4,5,10\end{array}\)

\(\begin{array}{c}mergesort\left( {4,\,10,\,\,1,\,\,5,\,\,3,\,\,8,\,\,7,\,\,2,\,\,6,\,\,9} \right) = merge\left( {mergesort\left( {4,\,10,\,\,1,\,\,5,\,\,3} \right),mergesort\left( {8,\,\,7,\,\,2,\,\,6,\,\,9} \right)} \right)\\ = merge\left( {1,3,4,5,10,2,6,7,8,9} \right)\\ = 1,\;2,\;3,\;4,\;5,\,\,6,\;7,\;8,\;9,\;10\end{array}\)

Hence, the list in increasing order using the merge sort algorithm is.

\(1,\,\,2,\,\,3,\,\,4,\,\,5,\,\,6,\,\,7,\,\,8,\,9,10\)

04

Step 4:(c) Define big-O estimate

The number of comparisons needed to merge short a list with\(n\)elements is

\(O\left( {n\log n} \right)\)

Since the list has 10 elements therefore\(n = 10\)

Therefore, big-O estimate for the number of comparisons used by the merge sort is \(O\left( {10\log 10} \right)\)

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