java实现归并排序算法

在学习算法的过程中,我们难免会接触很多和排序相关的算法。总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的。那么现在我们将要进行基本的归并排序算法的讲解

归并排序就是将未排序的数组进行对半划分成两个数组,划分后的数组只有原来数组的一半数量的元素。然后在对划分的两个数组再继续划分,循环此操作,直到划分的数组中只有一个元素时停止划分,然后对于划分完成的数组进行归并排序操作。将两个已经划分完成的数组合并成一个有序的数组,直到最后合并成一个包含所有元素的数组,合并排序操作完成。下面以图形来演示下归并排序的过程。

假设有一个未排序数组:{3,2,4,1},下面为数组的划分过程,先将数组对半划分为{3,2}和{4,1}两个数组。然后在对这两个数组进行划分最后得到{3},{2},{4},{1}四个数组,划分完成。

接下来对数组进行归并,先将{3}和{2}这两个数组合并成一个有序的数组{2,3},同理对4,1进行相同的操作,得到{1,4},然后在将合并好的这两个有序数组进行合并,最后合并成{1,2,3,4},归并完成。

归并排序算法用java代码实现如下:

 public static void MergeSort(int[] array,int head,int tail){ // 判断数组的头部索引是否小于尾部索引 if(head 

以上就是java实现归并排序算法的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » Java