归并排序就是递归得将原始数组递归对半分隔,直到不能再分(只剩下一个元素)后,开始从最小的数组向上归并排序。
- 将一个数组拆分为两个,从中间点拆开,通过递归操作来实现一层一层拆分。
- 从左右数组中选择小的元素放入到临时空间,并移动下标到下一位置。
- 重复步骤2直到某一下标达到尾部。
- 将另一序列剩下的所有元素依次放入临时空间。
- 将临时空间的数据依次放入原数据数组
分解
public static void mergeSort(int[] a, int low, int high) {
//首先判断 low 和 high是否指向一个地方
// 正常情况下就是 ==
if(low == high) {
return;
}
int mid = (low + high)/2;
//先递归左边
mergeSort(a, low, mid);
//在递归右边
mergeSort(a, mid