選擇排序是一種簡單的排序算法,其基本思想是從未排序的序列中選擇最小(或最大)的元素,然后將其放到已排序的序列的末尾。
Java實(shí)現(xiàn)選擇排序有兩種方式:升序排序和降序排序。下面我們來詳細(xì)了解這兩種算法。
/** * 升序選擇排序 * @param arr 待排序數(shù)組 */ public static void selectionSortAscending(int[] arr) { int len = arr.length; for (int i = 0; i< len-1; i++) { int minIndex = i; for (int j = i+1; j< len; j++) { if (arr[j]< arr[minIndex]) { minIndex = j; } } if (minIndex != i) { int temp = arr[i]; arr[i] = arr[minIndex]; arr[minIndex] = temp; } } }
升序選擇排序的實(shí)現(xiàn)過程是這樣的:先遍歷待排序數(shù)組,找到未排序部分中的最小元素,將其與未排序部分的第一個元素進(jìn)行交換,然后繼續(xù)遍歷未排序部分,找到最小元素,將其與未排序部分的第二個元素交換,以此類推。
/** * 降序選擇排序 * @param arr 待排序數(shù)組 */ public static void selectionSortDescending(int[] arr) { int len = arr.length; for (int i = 0; i< len-1; i++) { int maxIndex = i; for (int j = i+1; j< len; j++) { if (arr[j] >arr[maxIndex]) { maxIndex = j; } } if (maxIndex != i) { int temp = arr[i]; arr[i] = arr[maxIndex]; arr[maxIndex] = temp; } } }
降序選擇排序是升序選擇排序的變種,其實(shí)現(xiàn)過程類似,只不過每次從未排序部分中選出最大元素進(jìn)行交換,借此實(shí)現(xiàn)降序排序。
無論是升序排序還是降序排序,選擇排序的時間復(fù)雜度都為O(n^2),不適用于大規(guī)模的數(shù)據(jù)排序。