@Ggmatch
2018-02-14T01:49:11.000000Z
字数 827
阅读 1211
归并排序 算法
前期准备:归并排序利用的是分治法思想,其重复的子问题是如何归并两个有序数组a[]和b[]到c[],这里实现为MergeOrderedArray。
具体思路:数组A,分成两个数组B、C,但是B、C不一定就是有序的,要不断地分,直至子数组都只有1个元素,当然有序,再合并起来,那么A就排序完毕了。这样通过先递归的分解数组,再合并数组就完成了归并排序。
//将二个有序数列a[first...mid]和a[mid...last]合并。void MergeOrderedArray(int a[], int first, int mid, int last, int temp[]){int i = first, j = mid + 1;int m = mid, n = last;int k = 0;while (i <= m && j <= n){if (a[i] <= a[j])temp[k++] = a[i++];elsetemp[k++] = a[j++];}while (i <= m)temp[k++] = a[i++];while (j <= n)temp[k++] = a[j++];for (i = 0; i < k; i++)a[first + i] = temp[i];}void MergeSort(int a[], int first, int last, int temp[]){if (first < last){int mid = (first + last) > 1;MergeSort(a, first, mid, temp); //左边有序MergeSort(a, mid + 1, last, temp); //右边有序MergeOrderedArray(a, first, mid, last, temp); //再将二个有序数列合并}}bool MergeSort(int a[], int n){int *p = new int[n]; //共一个辅助空间if (p == NULL)return false;mergesort(a, 0, n - 1, p);delete[] p;return true;}