1.6 KiB
1.6 KiB
Selection Sort
- Time Complexity: O(n^2) due to two nested loops.
- Space Complexity: O(1)
- Applications: Useful when memory write is a costly operation.
- Founder's Name: Oscar Wilde
Steps
- Divide the array into two sub-arrays Unsorted and Sorted. Initially, keep the sorted array as empty and unsorted array as the whole array.
- Remove the minimum element from unsorted array and place it at the end of sorted array.
- Repeat step 2 until the length of sorted array is equal to initial array and the length of unsorted array becomes 0.
- Return the sorted array.
Example
Given array is 13, 44, 5, 34, 3
Sorted array is 3, 5, 13, 34, 44
First pass
Unsorted array: [13, 44, 5, 34, 3]
Minimum in an unsorted array: 3
Sorted array: [3]
Second pass
Unsorted array: [13, 44, 5, 34]
Minimum in unsorted array: 5
Sorted array: [3, 5]
Third pass
Unsorted array: [13, 44, 34]
Minimum in an unsorted array: 13
Sorted array: [3, 5, 13]
Fourth pass
Unsorted array: [44, 34]
Minimum in an unsorted array: 34
Sorted array: [3, 5, 13, 34]
Fifth pass
Unsorted array: [44]
Minimum in an unsorted array: 44
Sorted array: [3, 5, 13, 34, 44]
Unsorted array: []
Return the sorted array.