12、数据结构与算法 - 基础:排序算法之选择排序
1、选择排序基本介绍
选择排序(select sorting)是一种简单的排序方法,它的原理是:从需要排序的数据中,按照指定规则选出某一元素,再按照规定交换位置达到排序的目的。选择排序是不稳定的排序方法
选择排序时间复杂度
选择排序的交换操作介于 0 和 (n - 1) 次之间,比较操作为 n(n - 1) / 2 次之间,赋值操作介于 0 和 3(n - 1) 次之间。比较次数 O(n^2),比较次数与关键字的初始状态无关。
选择排序与冒泡排序相比,交换次数较少,比冒泡排序更快,最好的情况是有序,交换 0 次,最坏情况交换 n - 1 次,逆序交换 n / 2 次。
2、选择排序思路
1、 选择排序一共有数组大小-1轮排序,每轮排序都是一个循环;
2、 按照循环的规则进行比较,找到对应的数后进行交换;
3、 重复进行上一步操作,直到所有元素均排序完毕;
3、选择排序代码示例
// 排序规则为最小的数,与第一个元素进行交换
public static void selectSort(int[] arr) {
int minIndex = 0; // 最小值下标
int min = arr[0]; // 第一个元素
for(int i = 0 + 1; i < arr.length; i++) {
// 循环找到最小值
if(min > arr[i]) {
// 找到最小的值
min = arr[i];
minIndex = j;
}
}
// 第一个元素与最小值交换位置
arr[minIndex] = arr[0];
arr[0] = min;
}
选择排序代码具体实现
public static void selectSort(int[] arr) {
// 外层循环控制遍历次数
for(int i = 0; i < arr.length - 1; i++ ){
int minIndex = i; // 最小值下标
int min = arr[i]; // 第 i 个位置的元素
for(int j = i + 1; j < arr.length; j++) {
// 找到后面的最小的元素
if(min > arr[j]) {
min = arr[j];
minIndex = j;
}
}
// 最小值下标为 i 的话,不用进行交换
if (minIndex != i) {
arr[minIndex] = arr[i];
arr[i] = min;
}
}
}