[关闭]
@Ggmatch 2018-02-14T09:49:11.000000Z 字数 827 阅读 1093

归并排序

归并排序 算法


算法思想

前期准备:归并排序利用的是分治法思想,其重复的子问题是如何归并两个有序数组a[]和b[]到c[],这里实现为MergeOrderedArray。

具体思路:数组A,分成两个数组B、C,但是B、C不一定就是有序的,要不断地分,直至子数组都只有1个元素,当然有序,再合并起来,那么A就排序完毕了。这样通过先递归的分解数组,再合并数组就完成了归并排序。

算法实现

  1. //将二个有序数列a[first...mid]和a[mid...last]合并。
  2. void MergeOrderedArray(int a[], int first, int mid, int last, int temp[])
  3. {
  4. int i = first, j = mid + 1;
  5. int m = mid, n = last;
  6. int k = 0;
  7. while (i <= m && j <= n)
  8. {
  9. if (a[i] <= a[j])
  10. temp[k++] = a[i++];
  11. else
  12. temp[k++] = a[j++];
  13. }
  14. while (i <= m)
  15. temp[k++] = a[i++];
  16. while (j <= n)
  17. temp[k++] = a[j++];
  18. for (i = 0; i < k; i++)
  19. a[first + i] = temp[i];
  20. }
  21. void MergeSort(int a[], int first, int last, int temp[])
  22. {
  23. if (first < last)
  24. {
  25. int mid = (first + last) > 1;
  26. MergeSort(a, first, mid, temp); //左边有序
  27. MergeSort(a, mid + 1, last, temp); //右边有序
  28. MergeOrderedArray(a, first, mid, last, temp); //再将二个有序数列合并
  29. }
  30. }
  31. bool MergeSort(int a[], int n)
  32. {
  33. int *p = new int[n]; //共一个辅助空间
  34. if (p == NULL)
  35. return false;
  36. mergesort(a, 0, n - 1, p);
  37. delete[] p;
  38. return true;
  39. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注