归并排序(分治、递归)
public class MergeSort { public static void mergeSort(int[] arr) { //排序算法边界判断 if (arr == null || arr.length < 2) { return; } process(arr, 0, arr.length - 1); } private static void process(int[] arr, int L, int R) { if (L == R) { return; } int mid = L + ((R - L) >> 1); process(arr, L, mid); process(arr, mid + 1, R); merge(arr, L, mid, R); } private static void merge(int[] arr, int L, int mid, int R) { //开辟一个辅助数组 int[] help = new int[R - L + 1]; int i = 0; int p1 = L; int p2 = mid + 1; while (p1 <= mid && p2 <= R) { help[i++] = arr[p1] <= arr[p2] ? arr[p1++] : arr[p2++]; } //当左组越界,就把右边所有元素放入辅助数组 while (p1 <= mid) { help[i++] = arr[p1++]; } //当右组越界,就把左边所有元素放入辅助数组 while (p2 <= R) { help[i++] = arr[p2++]; } //把辅助数组的元素拷贝回原数组 for (int n = 0; n < help.length; n++) { arr[L+n] = help[n]; } } public static void printArray(int[] arr) { for (int array : arr) { System.out.println(array); } } public static void main(String[] args) { int[] arr = {3, 6, 8, 7, 0, 9, 1, 4}; mergeSort(arr); printArray(arr); } }
算法思想:
学习的博客多用于在笔记中,防止笔记过于臃肿,所以将样例及运行结果放在博客中,后以超链接的形式记录在笔记中,所以有些博文过于单薄。如果有小伙伴遇到问题欢迎评论,看到就会回复,学渣一枚,加油努力。