java实现归并排序算法

所属分类: 软件编程 / java 阅读数: 73
收藏 0 赞 0 分享

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

假设有一个未排序数组:{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 < tail){
        int middle = (head+tail)/2;
        MergeSort(array,head,middle);
        MergeSort(array,middle+1,tail);
        Merge(array,head,middle,tail);
      }  
    }

    public static void Merge(int[] array, int head, int middle, int tail) {
      // TODO Auto-generated method stub
      int[] temp = new int[tail - head + 1];
      int a = head;
      int b = middle + 1;
      int i = 0;
      // 对于两个数组中的数进行比较,将较小的值存放在临时数组中
      while(a <= middle && b <=tail){
        
        if(array[a] < array[b]){
          temp[i++] = array[a++];  
        }
        else{
          temp[i++] = array[b++];
        } 
      }
      
      // 将未参与比较的数组中的数添加到临时数组中
      while(a <= middle){
        temp[i++] = array[a++];
      }
      
      while(b <= tail){
        temp[i++] = array[b++];
      }
      
      // 将排好序的数组放回到array数组中
      System.arraycopy(temp,0,array,head,tail - head + 1);
    }

更多精彩内容其他人还在看

Java基于反射机制实现全部注解获取的方法示例

这篇文章主要介绍了Java基于反射机制实现全部注解获取的方法,结合实例形式分析了java反射机制获取注解的具体实现方法与操作注意事项,需要的朋友可以参考下
收藏 0 赞 0 分享

Java 信号量Semaphore的实现

这篇文章主要介绍了Java 信号量Semaphore的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

eclipse+maven+spring mvc项目基本搭建过程

这篇文章主要介绍了eclipse+maven+spring mvc项目基本搭建过程,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Spring boot集成swagger2生成接口文档的全过程

这篇文章主要给大家介绍了关于Spring boot集成swagger2生成接口文档的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0 赞 0 分享

Java冒泡排序法和选择排序法的实现

这篇文章主要介绍了Java冒泡排序法和选择排序法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Spring Cloud Alibaba教程之Sentinel的使用

这篇文章主要介绍了Spring Cloud Alibaba教程之Sentinel的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Josephus环的四种解法(约瑟夫环)基于java详解

这篇文章主要介绍了Josephus环的四种解法(约瑟夫环)基于java详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Java继承Thread类创建线程类示例

这篇文章主要介绍了Java继承Thread类创建线程类,结合实例形式分析了java线程操作相关使用技巧与注意事项,需要的朋友可以参考下
收藏 0 赞 0 分享

Java使用Callable和Future创建线程操作示例

这篇文章主要介绍了Java使用Callable和Future创建线程操作,结合实例形式分析了java使用Callable接口和Future类创建线程的相关操作技巧与注意事项,需要的朋友可以参考下
收藏 0 赞 0 分享

springBoot使用JdbcTemplate代码实例

这篇文章主要介绍了springBoot使用JdbcTemplate代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多