-
Instead of dividing the list once, a recursive mergeSort will keep dividing the list in half until the sublists are one or two values in length.
-
When developing a recursive solution, a key step is identifying the base case of the solution. What situation will terminate the recursion? In this case, a sublist of one or two values will be our two base cases.
- Let's try and work through the recursive mergeSort of a list of eight values.
data:image/s3,"s3://crabby-images/f5c07/f5c070d9d01e8ebb21c5f519c9ba771e7b857c6c" alt=""
The list is divided into two sublists:
data:image/s3,"s3://crabby-images/bd60b/bd60b79cb4cf691916dc6c5086eebf7633abf9f1" alt=""
Now let's work on the left sublist. It will be divided into lists of two.
data:image/s3,"s3://crabby-images/1d644/1d644bda00f40936194080a9f51aff1bac3bf871" alt=""
Each list of two is now very easy to sort. After each list of two is sorted, we then merge these two lists back into a list of four.
data:image/s3,"s3://crabby-images/25e32/25e32ffdda869f14d865b5bb9deb1745617f8ea6" alt=""
Now the algorithm proceeds to solve the right sublist (positions 5-8) recursively. Then the two lists of four are merged back together.
data:image/s3,"s3://crabby-images/4af0a/4af0a2650f70c4be6a930b4d96fe16f1de4dec0f" alt=""