What is Merge Sort in One Sentence?
Merge Sort is a computer science sorting algorithm, which essentially means that it takes a bunch of numbers and puts them in order.
What is an Example of Merge Sort?
We’ll start with a worked example to illustrate what merge sort is all about.
Let’s say that I have 4 numbers.
My numbers are (1, 41, 5, 0)
data:image/s3,"s3://crabby-images/bb3f2/bb3f295e0d039aca28e20ca09b0e32072a37b467" alt="Merge sort, illustrated with an example starting with the numbers (1, 41, 5, 0)"
I want to sort these numbers out, so that they’re in increasing order.
In Merge Sort, I take my numbers and I give half of them to my friends, Bob and John.
So now, Bob has (1, 41) and John has (5, 0).
data:image/s3,"s3://crabby-images/9db32/9db32fce6f3b22867cf2a18ed5676869be30e981" alt="Merge sort starts by taking a bunch of numbers and splitting it into 2 different lists."
And now, Bob asks himself: “Is 1 less than 41?”
It is!
So, 1 comes before 41.
Therefore, Bob’s numbers have been sorted: (1, 41).
data:image/s3,"s3://crabby-images/792f7/792f7881249de47bf4fd609acddde946700dd3ab" alt="From there, merge sort will sort each sublist."
Now, it’s John’s turn.
Does 5 come before 0? No! 0 comes before 5.
So, John re-orders his numbers.
data:image/s3,"s3://crabby-images/2844a/2844a21d37aedca7ae498de4cd2e8a89647c9c64" alt=""
Merge Sort – Returning Numbers Back
And now, they both give their numbers back to Kushal.
data:image/s3,"s3://crabby-images/ecc37/ecc37b4de91ae6267a42136db927df035124953b" alt="Merge sort sorts its two sublists and then returns it to the original caller."
And now, Kushal has to “merge” the (1, 41) and (0, 5) into a new sorted list.
So, he points to the first item in both lists.
Between the 1 and 0, what comes first? The 0 comes first. So, we add it to the list of sorted numbers.
data:image/s3,"s3://crabby-images/7459c/7459c7c8ea6ea2dc732a5041bc253f32f5140e91" alt="We determine what comes first between 1 and 0."
And now, we increment the arrow pointing to the 0.
So now, the right arrow points to 5.
data:image/s3,"s3://crabby-images/41753/4175386fb53656322d75bcf5844e216f9bd3fbfc" alt="Merge sort then determines what comes first between 1 and 5."
And we repeat. Between 1 and 5, 1 comes first. Add 1 to the sorted list and increment the arrow that points to 1.
data:image/s3,"s3://crabby-images/ec1c0/ec1c059ef626aeaf652d450312a81ca0721672bc" alt="Merge sort then determines what comes first between 1 and 5."
Now, between 41 and 5, 5 comes first. Add 5 to the list and increment the arrow.
data:image/s3,"s3://crabby-images/0e524/0e52464975d940998c47c8663dc38ae613d9f275" alt="Merge sort then determines what comes first between 41 and 5."
At this point, length of our sorted numbers is one less than the length of our unsorted numbers. This means that we have 1 more number to sort.
And that is our last number, 41.
data:image/s3,"s3://crabby-images/1ae28/1ae28f6b69fa5baeb2c9901079ad4506e3876405" alt="Merge Sort poster that provides an answer to "What is merge sort?", courtesy of kushaltimsina.com"
There you have it! Merge sort, clearly explained.
If you’re a new computer science student, or are thinking about getting into computer science, check out my advice for new computer science students.
Thanks for reading! If this helped you, make sure to subscribe to Kushal Writes for more awesome computer science concepts to level up your programming skills.