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