欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

Java選擇排序(升序和降序)

黃文隆1年前6瀏覽0評論

選擇排序是一種簡單的排序算法,其基本思想是從未排序的序列中選擇最小(或最大)的元素,然后將其放到已排序的序列的末尾。

Java實現選擇排序有兩種方式:升序排序和降序排序。下面我們來詳細了解這兩種算法。

/**
* 升序選擇排序
* @param arr 待排序數組
*/
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;
}
}
}

升序選擇排序的實現過程是這樣的:先遍歷待排序數組,找到未排序部分中的最小元素,將其與未排序部分的第一個元素進行交換,然后繼續遍歷未排序部分,找到最小元素,將其與未排序部分的第二個元素交換,以此類推。

/**
* 降序選擇排序
* @param arr 待排序數組
*/
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;
}
}
}

降序選擇排序是升序選擇排序的變種,其實現過程類似,只不過每次從未排序部分中選出最大元素進行交換,借此實現降序排序。

無論是升序排序還是降序排序,選擇排序的時間復雜度都為O(n^2),不適用于大規模的數據排序。