Skip to content

Latest commit

 

History

History
 
 

SelectionSort

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

Selection sort

Selection sort is a sorting algorithm, specifically an in-place comparison sort. It has O(n2) time complexity, making it inefficient on large lists, and generally performs worse than the similar insertion sort. Selection sort is noted for its simplicity, and it has performance advantages over more complicated algorithms in certain situations, particularly where auxiliary memory is limited.

Source: Wikipedia page for Selection sort

Kotlin playground link

Code

fun <T : Comparable<T>> selectionSort(items: MutableList<T>): MutableList<T> {
    if (items.isEmpty()) {
        return items
    }
    for (idx in 0..items.count()) {
        val array = items.subList(0, items.count() - idx)
        val minItem = array.minOrNull()
        val indexOfMinItem = array.indexOf(minItem)

        if (minItem != null) {
            items.removeAt(indexOfMinItem)
            items.add(minItem)
        }
    }
    return items
}