Quicksort
Now, let's study the famous quicksort algorithm!
We'll cover the following...
Introduction
Quicksort is the fastest known comparison-based sorting algorithm for arrays in the average case.
Caveat: Merge sort works better on linked lists, and there are other non-comparison based algorithms that outperform quicksort.
Quick sort algorithm
- 
Start with an array of n elements. 
- 
Choose a pivot element from the array to be sorted. 
- 
Partition the array into two unsorted subarrays, such that all elements in one subarray are less than the pivot and all the elements in the other subarray are greater than the pivot. 
- 
Elements that are equal to the pivot can go in either subarray. 
- 
Sort each subarray recursively to yield two sorted subarrays. 
- 
Concatenate the two sorted subarrays and the pivot to yield one sorted array. 
Note that if we always pick the smallest element in the array as the pivot, the left-hand side array is always empty, and all the remaining items end up in the right-hand side array. This means that the array will be subdivided a total of ...