步骤:
数组长度为n
- 0 - n-1 位置选出最小的数放到0位置
- 1-n-1 位置选出最小的数放到1位置
- 重复上述步骤
coding
public static void selectionSort(int[] arr) {
if (arr == null || arr.length < 2) {
return;
}
for (int i = 0; i < arr.length - 1; i++) {
int minIndex = i;
for (int j = i + 1; j < arr.length; j++) {
// 获取小于arr[minIndex]数
minIndex = arr[j] < arr[minIndex] ? j : minIndex;
}
swap(arr, minIndex, i);
}
// 交换下标在i位置与j位置的数
public static void swap(int[] arr, int i, int j) {
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
}
时间复杂度:O(N^2)
额外空间复杂度:O(1)
稳定性:无