选择排序的思想是每次从未排序的部分中选择最小的元素,然后将其放在已经排序部分的末尾。
- 遍历数组,从第一个元素开始,将其视为当前最小元素。
- 在未排序的部分中,找到最小的元素,并记录其索引。
- 将最小的元素与当前位置的元素交换位置
- 重复步骤2和步骤3,直到遍历完整个数组
比如有一个数组arr=[8,2,4,5,1,6,0,1]
我们要进行选择排序,先选择最小的,然后选择第二小的,然后是选择第三小的,依次类推。
选择排序是一种是原地排序算法
选择排序算法是不稳定的排序算法
执行流程
- 从序列中找出最大的哪个元素,然后于最末尾的元素交换位置
- 执行完一轮之后,最后的哪个元素就是最大的元素
- 忽略掉上一轮中找到的最大元素,重复执行步骤1
java
package com.lut.sort;
import java.util.Arrays;
public class SelectionSort {
public static void main(String[] args) {
int[] arr = {8,2,4,5,1,6,0,1};
selectionSort(arr);
System.out.println(Arrays.toString(arr));
}
public static void selectionSort(int[] arr){
int n = arr.length;//获取数组的长度
for (int i = 0; i < n-1; i++) {
int minIndex = i;
for (int j = i; j < n; j++) {
if(arr[j] < arr[minIndex]){
minIndex = j;
}
}
int temp = arr[minIndex];
arr[minIndex] = arr[i];
arr[i] = temp;
}
}
}