当前位置:   article > 正文

排序——归并排序_归并排序 递推方程

归并排序 递推方程

如果要排序一个数组,我们先把数组从中间分成前后两部分,然后对前后两部分分别排序,再将排好序的两部分合并在一起,这样整个数组就都有序了。

 实现思路:

递推公式:merge_sort(p..r) =  merge( merge_sort (p...q), merge-sort(q+1..r) )

终止条件:  p>=r不用再继续分解

merge-sort(p...r)表示,给下标从p到r之间的数组排序。我们将这个排序问题转化为了两个子问 ,题, merge_sort(p...q)和merge-sort(q+1..r),其中下标q等于p和r的中间位置,也就是, (p+r)/2,当下标从p到q和从q+1到r这两个子数组都排好序之后,我们再将两个有序的子数组合并在一起,这样下标从p到r之间的数据就也排好序了。

 

代码:

  1.  // 归并排序算法, a是数组,n表示数组大小
  2.   public static void mergeSort(int[] a, int n) {
  3.     mergeSortInternally(a, 0, n-1);
  4.   }
  5.  
  6.   // 递归调用函数
  7.   private static void mergeSortInternally(int[] a, int p, int r) {
  8.     // 递归终止条件
  9.     if (p >= r) return;
  10.  
  11.     // 取p到r之间的中间位置q
  12.     int q = (p+r)/2;
  13.     // 分治递归
  14.     mergeSortInternally(a, p, q);
  15.     mergeSortInternally(a, q+1, r);
  16.  
  17.     // 将A[p...q]和A[q+1...r]合并为A[p...r]
  18.     merge(a, p, q, r);
  19.   }
  20.  
  21.   private static void merge(int[] a, int p, int q, int r) {
  22.     int i = p;
  23.     int j = q+1;
  24.     int k = 0; // 初始化变量i, j, k
  25.     int[] tmp = new int[r-p+1]; // 申请一个大小跟a[p...r]一样的临时数组
  26.    
  27.     // 1 排序
  28.     while (i<=q && j<=r) {
  29.       if (a[i] <= a[j]) {
  30.         tmp[k++] = a[i++]; // i++等于i:=i+1
  31.       } else {
  32.         tmp[k++] = a[j++];
  33.       }
  34.     }
  35.  
  36.     // 2 判断哪个子数组中有剩余的数据
  37.     int start = i;
  38.     int end = q;
  39.     if (j <= r) {
  40.       start = j;
  41.       end = r;
  42.     }
  43.  
  44.     // 3 将剩余的数据拷贝到临时数组tmp
  45.     while (start <= end) {
  46.       tmp[k++] = a[start++];
  47.     }
  48.  
  49.     // 4 将tmp中的数组拷贝回a[p...r]
  50.     for (i = 0; i <= r-p; ++i) {
  51.       a[p+i] = tmp[i];
  52.     }
  53. }


merge是这样执行的:

代码分析:

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/430077
推荐阅读
相关标签
  

闽ICP备14008679号