Leetcode 912 uses this algorithm and shows a practical implementation, check that out too - 912 Sort An Array
The merge sort algorithm is one of the most important algorithms to study in terms of understanding “programming”. It’s important as in, the concepts (recursion, divide and conquer, sorting)
that one learns while implementing this algorithm is widely used in current programming scenarios - even LeetCode.
Basic idea
Let’s go from the basics, so Merge Sort is a Divide and Conquer algorithm. That means, we divide the algorithm into smaller subproblems - then gather the results of these subproblems to generate our final result. Don’t get confused with Dynamic Programming. Remember, DP involves breaking down input in to smaller overlapping
subproblems when Divide and Conquer is breaking down input into smaller non-overlapping
subproblems. Also, DP is an optimization technique, divide and conquer not so much.
Algorithm:
(1) Break down the input array into two smaller subarrays, and then break them down into two even smaller subarrays, and then break down into two even smaller subarrays, and then break down into even smaller subarrays, and then break… hahaha you get it. Ik, it gives recursion.
(2) Once every smaller subarray has a single element, merge these ‘single’ elements into one large array by checking which comparing two elements at a time.
(3) This fully formed array will now be sorted.
Note: Merge Sort creates a new array that is sorted, if you want in-place sorting for an array - you might want to check out QuickSort.
About the code:
We basically need two functions - one to break down the arrays into smaller subarrays, and one to join these atomic subarrays into one larger final array.
Pseudocode
Runtime and memory analysis
We are breaking down input by half at every step (log N), but this happens for N times in an array with N elements. So the runtime becomes .
The memory usage is , because remember that in the merge function, we generate new array and that is returned.
On a sidenote
I highly recommend reading Zhijun Liao’s post on LeetCode. He explains a series of problems on LeetCode that could be solved by understanding how and when to apply Binary Search. He also shows a wonderful template that I highly recommend following.
— A