归并排序

将两个或两个以上的有序表组合成一个新的有序表

   1 /**
  2  * 
  3  *归并排序:Java
  4  * 
  5  * 
  6  */
  7 
  8 public class MergeSort {
  9 
 10     /*
 11      * 将一个数组中的两个相邻有序区间合并成一个
 12      *
 13      * 参数说明:
 14      *     a -- 包含两个有序区间的数组
 15      *     start -- 第1个有序区间的起始地址。
 16      *     mid   -- 第1个有序区间的结束地址。也是第2个有序区间的起始地址。
 17      *     end   -- 第2个有序区间的结束地址。
 18      */
 19     public static void merge(int[] a, int start, int mid, int end) {
 20         int[] tmp = new int[end-start+1];    // tmp是汇总2个有序区的临时区域
 21         int i = start;            // 第1个有序区的索引
 22         int j = mid + 1;        // 第2个有序区的索引
 23         int k = 0;                // 临时区域的索引
 24 
 25         while(i <= mid && j <= end) {
 26             if (a[i] <= a[j])
 27                 tmp[k++] = a[i++];
 28             else
 29                 tmp[k++] = a[j++];
 30         }
 31 
 32         while(i <= mid)
 33             tmp[k++] = a[i++];
 34 
 35         while(j <= end)
 36             tmp[k++] = a[j++];
 37 
 38         // 将排序后的元素,全部都整合到数组a中。
 39         for (i = 0; i < k; i++)
 40             a[start + i] = tmp[i];
 41 
 42         tmp=null;
 43     }
 44 
 45     /*
 46      * 归并排序(从上往下)
 47      *
 48      * 参数说明:
 49      *     a -- 待排序的数组
 50      *     start -- 数组的起始地址
 51      *     endi -- 数组的结束地址
 52      */
 53     public static void mergeSortUp2Down(int[] a, int start, int end) {
 54         if(a==null || start >= end)
 55             return ;
 56 
 57         int mid = (end + start)/2;
 58         mergeSortUp2Down(a, start, mid); // 递归排序a[start...mid]
 59         mergeSortUp2Down(a, mid+1, end); // 递归排序a[mid+1...end]
 60 
 61         // a[start...mid] 和 a[mid...end]是两个有序空间,
 62         // 将它们排序成一个有序空间a[start...end]
 63         merge(a, start, mid, end);
 64     }
 65 
 66 
 67     /*
 68      * 对数组a做若干次合并:数组a的总长度为len,将它分为若干个长度为gap的子数组;
 69      *             将"每2个相邻的子数组" 进行合并排序。
 70      *
 71      * 参数说明:
 72      *     a -- 待排序的数组
 73      *     len -- 数组的长度
 74      *     gap -- 子数组的长度
 75      */
 76     public static void mergeGroups(int[] a, int len, int gap) {
 77         int i;
 78         int twolen = 2 * gap;    // 两个相邻的子数组的长度
 79 
 80         // 将"每2个相邻的子数组" 进行合并排序。
 81         for(i = 0; i+2*gap-1 < len; i+=(2*gap))
 82             merge(a, i, i+gap-1, i+2*gap-1);
 83 
 84         // 若 i+gap-1 < len-1,则剩余一个子数组没有配对。
 85         // 将该子数组合并到已排序的数组中。
 86         if ( i+gap-1 < len-1)
 87             merge(a, i, i + gap - 1, len - 1);
 88     }
 89 
 90     /*
 91      * 归并排序(从下往上)
 92      *
 93      * 参数说明:
 94      *     a -- 待排序的数组
 95      */
 96     public static void mergeSortDown2Up(int[] a) {
 97         if (a==null)
 98             return ;
 99 
100         for(int n = 1; n < a.length; n*=2)
101             mergeGroups(a, a.length, n);
102     }
103 
104     public static void main(String[] args) {
105         int i;
106         int a[] = {80,30,60,40,20,10,50,70};
107 
108         System.out.printf("before sort:");
109         for (i=0; i<a.length; i++)
110             System.out.printf("%d ", a[i]);
111         System.out.printf("\n");
112 
113         mergeSortUp2Down(a, 0, a.length-1);        // 归并排序(从上往下)
114         //mergeSortDown2Up(a);                    // 归并排序(从下往上)
115 
116         System.out.printf("after  sort:");
117         for (i=0; i<a.length; i++)
118             System.out.printf("%d ", a[i]);
119         System.out.printf("\n");
120     }
121 }

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 归并排序 所谓归并,就是将两个或两个以上的有序表合并成一个新的有序表。如下图所示,有两个已经排好序的有序表A[1]...
    JackChen1024阅读 2,376评论 0 4
  • 归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非...
    NEXTFIND阅读 1,009评论 0 0
  • 简介: 归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)...
    jeckHao阅读 348评论 0 1
  • 归并排序(Merge)是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列...
    李序锴阅读 199评论 0 0
  • 我小的时候是在爸爸单位的家属院里长大的,一个宽敞的大院子里分布着几排红砖瓦房,里面住着几十户人家。记得同龄的...
    DorisGuo_bc09阅读 255评论 0 0