每次找到最大的数字放在第首位,依次类推

    1. package class01;
    2. import java.util.Arrays;
    3. public class Code01_SelectionSort {
    4. public static void selectionSort(int[] arr) {
    5. if (arr == null || arr.length < 2) {
    6. return;
    7. }
    8. // 0 ~ N-1 找到最小值,在哪,放到0位置上
    9. // 1 ~ n-1 找到最小值,在哪,放到1 位置上
    10. // 2 ~ n-1 找到最小值,在哪,放到2 位置上
    11. for (int i = 0; i < arr.length - 1; i++) {
    12. int minIndex = i;
    13. for (int j = i + 1; j < arr.length; j++) { // i ~ N-1 上找最小值的下标
    14. minIndex = arr[j] < arr[minIndex] ? j : minIndex;
    15. }
    16. swap(arr, i, minIndex);
    17. }
    18. }
    19. //交换两个元素
    20. public static void swap(int[] arr, int i, int j) {
    21. int tmp = arr[i];
    22. arr[i] = arr[j];
    23. arr[j] = tmp;
    24. }
    25. }