Given an unsorted array of n
elements, write a function to sort the array.
- Find out the maximum element (let's call it
max
) from the given array. - Initialize an array of length
max+1
with all elements set to 0 to store the array's count. - Store the count of each element at their respective index in the array's count.
- Store cumulative sum of the elements of the count array. It helps in placing the elements into the correct index of the sorted array.
- Find the index of each element of the original array in the array's count. This gives the cumulative count.
- Place the element at the index calculated and decrease its count by one.
O(n+k)
: where k
is the range of the non-negative key values.
O(n+k)
: where k
is the range of the non-negative key values.
- Harold H. Seward.
countingSort(array, size)
max <- find largest element in array
initialize count array with all zeros
for j <- 0 to size
find the total count of each unique element and
store the count at jth index in count array
for i <- 1 to max
find the cumulative sum and store it in count array itself
for j <- size down to 1
restore the elements to array
decrease count of each element restored by 1