Question : How much time Insertion sort takes to sort an array of size n in below form?
arr = 2, 1, 4, 3, 6, 5,….i, i-1, …..n, n-1
Answer : At first look, it seems like Insertion Sort would take O(n2) time, but it actually takes O(n) time
How? Let us take a closer look at below code.
/* Function to sort an array using insertion sort*/
void insertionSort(int arr, int n)
for (int i = 1; i = 0 && arr[j] > key)
arr[j+1] = arr[j];
j = j-1;
arr[j+1] = key;
If we analyze the input carefully we see that every element is only one position away from its position in sorted array. The outer for loop will run till ‘n’ and the inner while loop would take “constant” steps of 1 swap and 2 comparisons. Since, while loop takes constant time and for loop runs for ‘n’ element, so overall complexity is O(n)
Alternate Answer : Another way to look at this is, time taken by Insertion Sort is proportional to number of inversions in an array. In above example type, number of inversions is n/2, so overall time complexity is O(n)
If you like GeeksforGeeks and would like to contribute, you can also write an article using write.geeksforgeeks.org or mail your article to email@example.com. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.
Feeling lost in the world of random DSA topics, wasting time without progress? It's time for a change! Join our DSA course, where we'll guide you on an exciting journey to master DSA efficiently and on schedule.
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 geeks!