算法面经--选择排序
2020-06-12 本文已影响0人
永不熄灭的火焰_e306
选择排序
介绍:是从欲排序的数据中,按指定的规则选出某一元素,再依规定交换位置后达到排序的目的。
一、算法思路
选择排序(select sorting)也是一种简单的排序方法。它的基本思想是:第一次从 arr[0]~arr[n-1]中选取最小值, 与 arr[0]交换,第二次从 arr[1]~arr[n-1]中选取最小值,与 arr[1]交换,第三次从 arr[2]~arr[n-1]中选取最小值,与 arr[2] 交换,…,第 i 次从 arr[i-1]~arr[n-1]中选取最小值,与 arr[i-1]交换,…, 第 n-1 次从 arr[n-]~arr[n-1]中选取最小值, 与 arr[n-2]交换,总共通过 n-1 次,得到一个按排序码从小到大排列的有序序列。
实现图解:
选择排序1.png 选择排序2.png[图片上传失败...(image-ebec15-1591967993075)]
二、代码实现
//选择排序
public static void selectSort(int[] arr){
for(int i=0;i<arr.length-1;i++){
int minIndex= i;
int min = arr[i];
for(int j=i+1;j<arr.length;j++){
if(arr[j]<min){
min = arr[j]; //重置min和minIndex
minIndex = j;
}
}
//将最小值放在arr[i],即交换
if(minIndex!=i){
arr[minIndex] = arr[i];
arr[i] = min;
}
}
}