1.排序思想
先拿出最小的,与排在第一个交换位置(有可能是它自己),之后在剩下的里面再选择最小的,与排在第二个交换位置,以此类推。
2.代码实现
public class SelectionSort_GenericClass { private SelectionSort_GenericClass(){}; //思想: 循环不变量 arr[i....n)未排序, arr[0..i)已经排序 // arr[i...n)中的最小值要放到 arr[i]的位置 public static <E extends Comparable<E>> void sort(E[] arr) { for(int i=0; i < arr.length; i++) { //选择 arr[i...n)中的最小值的索引 int minIndex=i; for(int j = i; j < arr.length; j++) { if(arr[j].compareTo(arr[minIndex]) < 0 ) { minIndex = j; } } swap(arr, i, minIndex); } } private static <E> void swap(E[] arr, int i, int j) { E t = arr[i]; arr[i] = arr[j]; arr[j] = t; } public static void main(String[] args) { Integer[] arr = {1,4,6,3,8,2,9}; SelectionSort_GenericClass.sort(arr); for(int e:arr) { System.out.println(e + " "); } System.out.println(); } }
时间复杂度是O(n^2)级别的。