对选择排序进行详细分解,逐步递进,便于理解选择排序。
一、代码
import java.util.Arrays;
public class SelectSort {
public static void main(String[] args) {
int[] arr = { 101, 34, 119, 1 };
System.out.println("选择排序前:");
System.out.println(Arrays.toString(arr));
selectSort(arr);
System.out.println("选择排序后:");
System.out.println(Arrays.toString(arr));
}
public static void selectSort(int[] arr) {
int minIndex = 0;
int min = arr[0];
for (int j = 0 + 1; j < arr.length; j++) {
if (min > arr[j]) {
min = arr[j];
minIndex = j;
}
}
if (minIndex != 0) {
arr[minIndex] = arr[0];
arr[0] = min;
}
System.out.println("第一轮选择排序后:");
System.out.println(Arrays.toString(arr));
minIndex = 1;
min = arr[1];
for (int j = 1 + 1; j < arr.length; j++) {
if (min > arr[j]) {
min = arr[j];
minIndex = j;
}
}
if (minIndex != 1) {
arr[minIndex] = arr[1];
arr[1] = min;
}
System.out.println("第二轮选择排序后:");
System.out.println(Arrays.toString(arr));
minIndex = 2;
min = arr[2];
for (int j = 2 + 1; j < arr.length; j++) {
if (min > arr[j]) {
min = arr[j];
minIndex = j;
}
}
if (minIndex != 2) {
arr[minIndex] = arr[2];
arr[2] = min;
}
System.out.println("第三轮选择排序后:");
System.out.println(Arrays.toString(arr));
}
}
二、结果
选择排序前:
[101, 34, 119, 1]
第一轮选择排序后:
[1, 34, 119, 101]
第二轮选择排序后:
[1, 34, 119, 101]
第三轮选择排序后:
[1, 34, 101, 119]
选择排序后:
[1, 34, 101, 119]