Java人肉实现数组排序

这里没有使用Arrays.sort()排序方法,人肉手动实现几种经典排序算法。包括选择排序、冒泡排序、插入排序。

public static int[] selectSort(int[] ary) {// 选择排序

        for (int i = 0; i < ary.length - 1; i++) {
            for (int j = i + 1; j < ary.length; j++) {// 每轮选择一个最小的数与前一个数交换
                if (ary[i] > ary[j]) {
                    int temp = ary[i];
                    ary[i] = ary[j];
                    ary[j] = temp;
                }
            }
        }

        return ary;
    }


public static int[] bubbleSort(int[] ary) {// 冒泡排序
        // 比较相邻元素,把每轮最大的一个移到最后
        for (int i = 0; i < ary.length - 1; i++) {
            for (int j = 0; j < ary.length - 1 - i; j++) {
                if (ary[j] > ary[j + 1]) {
                    int temp = ary[j];
                    ary[j] = ary[j + 1];
                    ary[j + 1] = temp;
                }
            }
        }

        return ary;
    }


public static int[] insertSort(int[] ary) {// 插入排序
        // 假设前半段是有序数组,将后半段元素插入到有序数组中的合适位置
        int i;
        for (int j = 1; j < ary.length; j++) {// 遍历后半段数组
            int temp = ary[j];
            for (i = j - 1; i >= 0; i--) {
                if (temp < ary[i]) {
                    ary[i + 1] = ary[i];// 后移
                } else {
                    break;
                }
            }
            // 因为发生了i--
            // 若直接break 则没有进行i-- 意味着下述语句自己对自己赋值,结果不变
            ary[i + 1] = temp;// 移完之后把临时变量置入

        }

        return ary;
    }