归并排序是一种基于分治思想的排序算法。它将一个数组递归地分成两个子数组,然后排序这两个子数组,并将它们合并成一个有序的数组。下面是一个简单的归并排序的实现代码:
public static void mergeSort(int[] arr, int lo, int hi) {
if (lo >= hi) {
return;
}
int mid = (lo + hi) / 2;
mergeSort(arr, lo, mid);
mergeSort(arr, mid + 1, hi);
merge(arr, lo, mid, hi);
}
public static void merge(int[] arr, int lo, int mid, int hi) {
int[] temp = new int[hi - lo + 1];
int i = lo, j = mid + 1, k = 0;
while (i <= mid && j <= hi) {
if (arr[i] <= arr[j]) {
temp[k++] = arr[i++];
} else {
temp[k++] = arr[j++];
}
}
while (i <= mid) {
temp[k++] = arr[i++];
}
while (j <= hi) {
temp[k++] = arr[j++];
}
for (int p = 0; p < temp.length; p++) {
arr[lo + p] = temp[p];
}
}
在上面的代码中,mergeSort
方法实现了归并排序的分治过程,即不断地将数组分成两个子数组,分别进行排序并合并。merge
方法实现了两个有序数组的合并过程,其中 i
和 j
分别表示当前合并的两个数组的下标,k
则表示当前已经合并的元素个数。
归并排序的时间复杂度为 O ( n log n ) O(n \log n) O(nlogn),空间复杂度为 O ( n ) O(n) O(n),它比较适合用于排序链表等数据结构,因为它不需要像快速排序那样进行递归调用。