Summary
The sorting algorithms in this chapter all assume an array as a data storage structure.
Sorting involves comparing the keys of data items in the array and moving the items (actually, references to the items) around until they're in sorted order.
All the algorithms in this chapter execute in O(N2) time. Nevertheless, some can be substantially faster than others.
An invariant is a condition that remains unchanged while an algorithm runs.
The bubble sort is the least efficient, but the simplest, sort.
The insertion sort is the most commonly used of the O(N2) sorts described in this chapter.
A sort is stable if the order of elements with the same key is retained.
None of the sorts in this chapter require more than a single temporary variable, in addition to the original array.