文章目录
- 选择排序
- 详细代码
选择排序
选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。一般为两位for循环,内层for循环不断的缩减。不稳定,时间复杂度为 O(n²)
两层for循环
for (int i = 0; i < arr.length; i++) {
for (int j = i + 1; j < arr.length; j++) {}
}
详细代码
/**
* 作者:Hui
*/
/**
* 选择排序:每一次找出数组中最小的元素,并放在对应的索引位置上。
* 一般为两位for循环,内层for循环不断的缩减。
*
* @author: Hui
**/
public class SeletionSort {
public static void main(String[] args) {
//初始化数组
int[] arr = {1, 5, 3, 456, 5, 6, 7, 13, 9, 100};
System.out.println("排序前:");
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
SeletionSort seletionSort = new SeletionSort();
seletionSort.seletionSortMethod(arr);
System.out.println("排序后:");
for (int i = 0; i < arr.length; i++) {
System.out.println(arr[i]);
}
}
public int[] seletionSortMethod(int arr[]) {
int min;
for (int i = 0; i < arr.length; i++) {
min = i; //插入的索引位置
for (int j = i + 1; j < arr.length; j++) {
if (arr[j] < arr[min]) { //找到比当前值要小的就赋值
min = j;
}
}
if (i != min) { //比较完之后继续赋值
int temp = arr[i];
arr[i] = arr[min];
arr[min] = temp;
}
}
return arr;
}
}
我是小辉,24 届毕业生。当下是找工作ing,欢迎关注,持续分享。