打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
排序算法---归并排序

归并排序中的“归并”的意思是将两个或者两个以上的有序表组合成一个新的有序表。他的实现无论是顺序存储结构还是链表结构,都可以在O(m n)的时间级上实现。

复杂度:

时间复杂度:O(nlogn)

空间复杂度:O(n)

用途:

1、排序(速度仅次于快速排序,但较稳定)

2、求逆序对数

在实现单数组的归并排序之前,首先了解一下双数组的归并排序

这个双数组归并的前提是两个数组a和b都是已经排序好的

Java代码
 
  1. package sort;   
  2.   
  3. import java.util.Arrays;   
  4.   
  5. public class Test1 {   
  6.     public static void main(String args[])   
  7.     {   
  8.         int a[]={1,2,3,4,6,7,8,10};   
  9.         int b[]={1,2,5,9};   
  10.         int c[] = new int[a.length b.length];   
  11.         mergeSort(a,a.length,b,b.length,c);   
  12.         System.out.println(Arrays.toString(c));   
  13.     }   
  14.     public static void mergeSort(int a[],int n,int b[],int m,int c[])   
  15.     {   
  16.         int i,j,k;   
  17.         i=j=k=0;   
  18.         //只有满足i<n&&j<m才执行,分别扫描两个数组,将数组中的元素进行对比,从小到大赋值给临时数组c   
  19.         while(i<n&&j<m)   
  20.         {   
  21.             if(a[i]<b[j])   
  22.                 c[k ]=a[i ];   
  23.             else  
  24.                 c[k ]=b[j ];   
  25.         }   
  26.         //将剩余的a数组的元素放入c中   
  27.         while(i<n)   
  28.         {   
  29.             c[k ]=a[i ];   
  30.         }   
  31.         //将剩余的b数组的元素放入c中   
  32.         while(j<m)   
  33.         {   
  34.             c[k ]=b[j ];   
  35.         }   
  36.     }   
  37. }  
 

运行结果如下:

[1, 1, 2, 2, 3, 4, 5, 6, 7, 8, 9, 10]

下面开始实现单数组的归并排序算法

例如:49  38  65  97  76  13  27

思想:首先将数组中个单独的一个元素作为一个已经排序好的序列,然后,将两两相邻的元素进行归并排序,依次类推,直到最后归并为一个排序好的序列



 如上图:

首先将每个元素作为一个已经排序好的序列,一共7个序列

然后,将每两个相邻的序列归并为一个序列,如49 38归并排序后变成 38 49,依次分成了4个序列,然后再将之前已经排序好的两个相邻的序列进行排序,变成2个序列,每个序列都是排序好的,最后归并为一个排序好的序列

实现代码:

Java代码
 
  1. package sort;   
  2.   
  3. import java.util.Arrays;   
  4.   
  5. public class MergeSort {   
  6.     public static void main(String args[])   
  7.     {   
  8.         int[] array = {49,38,65,97,76,13,27};   
  9.         System.out.println(Arrays.toString(array));   
  10.         System.out.println("---------排序前-------------");   
  11.         mergeSort(array,0,array.length-1);   
  12.         System.out.println("---------排序后-------------");   
  13.         System.out.println(Arrays.toString(array));   
  14.     }   
  15.     /**  
  16.      * 这里依然需要递归来达到数组元素的排序,如果有两个已有元素的数组的话,就不用这么麻烦您了  
  17.      * 不过这种归并排序依然是效率最好的排序方法之一,而且还是稳定的(相比快速排序,快速排序不稳定)  
  18.      */  
  19.     public static void mergeSort(int array[],int low,int high)   
  20.     {   
  21.         if(low<high)   
  22.         {      
  23.             mergeSort(array,low,(low high)/2);//左边排序   
  24.             mergeSort(array,(low high)/2 1,high);//右边排序   
  25.             merge(array,low,(high low)/2,high);//将两个序列归并为一个序列   
  26.             System.out.println(Arrays.toString(array));    
  27.         }   
  28.     }   
  29.        
  30.     public static void merge(int array[],int low,int mid,int high)   
  31.     {   
  32.         int temp[]=new int[high-low 1];   
  33.         int i = low;   
  34.         int j = mid 1;   
  35.         int k=0;   
  36.         /**  
  37.          * 将array数组分成两个数组来扫描,每一次都会将前后相邻的两个有序的序列归并为一个有序的序列  
  38.          */  
  39.         while(i<=mid&&j<=high)   
  40.         {   
  41.             if(array[i]<=array[j])   
  42.                 temp[k ]=array[i ];   
  43.             else  
  44.                 temp[k ]=array[j ];      
  45.         }   
  46.         //下面这两种while循环每次只执行其中一个   
  47.         //将剩余的array[i]存入temp中   
  48.         while(i<=mid)   
  49.         {   
  50.             temp[k ]=array[i ];   
  51.         }   
  52.         //将剩余的array[j]存放到temp中   
  53.         while(j<=high)   
  54.         {   
  55.             temp[k ]=array[j ];   
  56.         }   
  57.         for(int m=0;m<temp.length;m )   
  58.         {   
  59.             array[low m]=temp[m];   
  60.         }   
  61.            
  62.     }   
  63. }  
 

运行结果如下:

[49, 38, 65, 97, 76, 13, 27]

---------排序前-------------

[38, 49, 65, 97, 76, 13, 27]

[38, 49, 65, 97, 76, 13, 27]

[38, 49, 65, 97, 76, 13, 27]

[38, 49, 65, 97, 13, 76, 27]

[38, 49, 65, 97, 13, 27, 76]

[13, 27, 38, 49, 65, 76, 97]

---------排序后-------------

[13, 27, 38, 49, 65, 76, 97]

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
算法系列15天速成
选择、冒泡、合并、快速、插入排序算法实现及性能分析
Java学习:递归
排序1+4:归并排序(MergeSort)和堆排序(HeapSort)
八大排序算法实战:思想与实现(下)
Java实现常见排序算法(二)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服