简简单单归并排序

90 阅读1分钟
public class MergeSort {

    public static void main(String[] args) {
        int[] array = Utils.gennerateArray(10, 10);
        Arrays.stream(array).forEach(value -> System.out.print(value+"\t"));
        mergeSort1(array);
        System.out.println();
        Arrays.stream(array).forEach(value -> System.out.print(value+"\t"));
    }
    
    public static void mergeSort1(int[] arr) {
        if (arr == null || arr.length < 2) {
            return;
        }
        process(arr, 0, arr.length -1);
    }

    //process函数定义:使 arr[L...R]范围上变成有序
    private static void process(int[] arr, int L, int R) {
        if (L == R) {// base case 一个数天然就是有序的
            return;
        }
        int mid = L + ((R - L) >> 1);
        //L...mid变有序
        process(arr, L, mid);
        //mid+1...R变有序
        process(arr, mid+1, R);
        //把L...mid和mid+1...R的数merge到一起,使之整体有序
        merge(arr, L, mid, R);
    }

    //把L...mid和mid+1...R的数merge到一起,使之整体有序
    private static void merge(int[] arr, int L, int M, int R) {
        //辅助数组
        int[] help = new int[R - L + 1];
        //辅助数组下标
        int i = 0;
        //p1为左部分数组下标开始位置
        int p1 = L;
        //p2为右部分数组下标开始位置
        int p2 = M + 1;
        //p1和p2都还没越界,谁小谁拷贝到help数组
        while (p1 <= M && p2 <= R) {
            //谁小谁拷贝到help数组,相等规定先拷贝左边
            help[i++] = arr[p1] <= arr[p2] ? arr[p1++] : arr[p2++];
        }
        //下面两个while自会有一个执行,因为p1和p2不可能同时越界
        while (p1 <= M) {
            //把p1剩下的元素全部拷贝到help
            help[i++] = arr[p1++];
        }
        while (p2 <= R) {
            //把p2剩下的元素全部拷贝到help
            help[i++] = arr[p2++];
        }
        //把help数组元素刷回arr
        for (i = 0; i < help.length; i++) {
            arr[L + i] = help[i];
        }
    }


}

排序结果:
排序前: 4 5 3 3 3 3 9 9 8 9
排序后: 3 3 3 3 4 5 8 9 9 9