Insertion Sort is a simple and intuitive sorting algorithm that builds the final sorted array one item at a time. It is much like the way you might sort playing cards in your hands: you take one card at a time and insert it into its correct position in the already sorted portion of the deck. Despite its simplicity, Insertion Sort can be quite efficient for small data sets or nearly sorted arrays.
How Insertion Sort Works
The Insertion Sort algorithm works by iterating through the array, starting from the second element (since a single element is trivially sorted). For each element, the algorithm compares it to the elements before it and inserts it into the correct position in the already sorted portion of the array.
Here’s how it works step-by-step:
- Start at the second element of the array, assuming that the first element is already sorted.
- Compare the current element with the element(s) before it.
- Shift larger elements to the right to make space for the current element.
- Insert the current element into the correct position.
- Repeat the process for all remaining elements in the array.
Example of Insertion Sort
Let’s sort the array: [5, 2, 9, 1, 5, 6]
.
- Step 1: Start with the second element (2). Compare it to 5. Since 2 is smaller, shift 5 to the right and place 2 in the first position.
Array after step 1:[2, 5, 9, 1, 5, 6]
- Step 2: Move to 9. 9 is larger than 5, so leave it in place.
Array after step 2:[2, 5, 9, 1, 5, 6]
- Step 3: Move to 1. Compare it with 9, 5, and 2. Shift all three elements to the right and place 1 in the first position.
Array after step 3:[1, 2, 5, 9, 5, 6]
- Step 4: Move to 5. Compare it with 9. Since 5 is smaller than 9, shift 9 to the right and place 5 in the correct position.
Array after step 4:[1, 2, 5, 5, 9, 6]
- Step 5: Move to 6. Compare it with 9. Since 6 is smaller than 9, shift 9 to the right and place 6 in the correct position.
Array after step 5:[1, 2, 5, 5, 6, 9]
Final sorted array: [1, 2, 5, 5, 6, 9]
Time Complexity
- Best Case: O(n) – When the array is already sorted, the algorithm only needs to make a single pass through the array, comparing each element with the previous one.
- Average Case: O(n²) – For a random arrangement of elements, Insertion Sort will compare and shift elements multiple times.
- Worst Case: O(n²) – When the array is in reverse order, the algorithm will compare each element with all the elements before it, resulting in the maximum number of comparisons and shifts.
Space Complexity
The space complexity of Insertion Sort is O(1), as it only requires a constant amount of additional space for swapping elements.
Advantages of Insertion Sort
- Simple to Understand and Implement: The algorithm is easy to implement, making it a great choice for learning sorting techniques.
- Efficient for Small Arrays: Insertion Sort performs well on small data sets or arrays that are already nearly sorted.
- Stable Sort: It maintains the relative order of equal elements, meaning that if two elements are equal, their order in the original array will be preserved in the sorted array.
- Adaptive: Insertion Sort adapts well to nearly sorted data, making it faster in those cases.
Disadvantages of Insertion Sort
- Inefficient for Large Arrays: The algorithm has O(n²) time complexity in the average and worst cases, making it inefficient for large datasets.
- Not Ideal for Large Data Sets: As the array size increases, Insertion Sort becomes significantly slower compared to more advanced algorithms like Merge Sort, Quick Sort, or Heap Sort.
When to Use Insertion Sort
- Small Data Sets: Insertion Sort is useful when you need to sort a small array or list, as it performs better than other algorithms with small inputs.
- Nearly Sorted Data: It is particularly effective when the array is already partially sorted or when only a few elements are out of place.
- Real-Time Applications: In scenarios where data is continuously being added and sorted incrementally (e.g., streaming data), Insertion Sort can be a good option for online sorting.
Insertion Sort is a straightforward, comparison-based sorting algorithm that excels with small or nearly sorted datasets. Its simplicity and adaptive nature make it a useful tool in certain situations, though its O(n²) time complexity makes it less suitable for large datasets. Understanding Insertion Sort provides a solid foundation for learning more advanced sorting algorithms, as it introduces key concepts such as comparisons, shifts, and sorting in place.