选择排序简介
选择排序(select sorting)也是一种简单的排序方法。它的基本思想是:
第一次:从 arr[0] ~ arr[n-1] 中选取最小值,与 arr[0] 交换;
第二次:从 arr[1] ~ arr[n-1] 中选取最小值,与 arr[1] 交换;
第三次:从arr[2] ~ arr[n-1] 中选取最小值,与 arr[2] 交换;
……;
第 i 次:从 arr[i-1] ~ arr[n-1] 中选取最小值,与 arr[i-1] 交换;
……;
第 n-1 次:从 arr[n-2]~arr[n-1] 中选取最小值,与 arr[n-2] 交换。
总共通过 n-1 次,得到一个按排序码从小到大排列的有序序列。
思路分析
代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
| public class SelectSort { public static void main(String[] args) { int[] arr = {101, 34, 119, 1, -1, 90, 123}; selectSort(arr); }
public static void selectSort(int[] arr) {
for (int i = 0; i < arr.length - 1; i++) { int minIndex = i; int min = arr[i]; for (int j = i + 1; j < arr.length; j++) { if (min > arr[j]) { min = arr[j]; minIndex = j; } }
if (minIndex != i) { arr[minIndex] = arr[i]; arr[i] = min; }
System.out.println("第" + (i + 1) + "轮后~~"); System.out.println(Arrays.toString(arr)); }
} }
|