归并排序!!--Java

原创 2016年08月29日 13:46:16

归并排序!!


建立在归并操作上的一种有效的排序算法,采用分治法

考虑如何将两个有序数列合并

只要比较两个数列的第一个数,谁小就先取谁

取了之后对应数列就移动到下一个数继续比较

如果有数列为空,那直接将另一个数列的数据一次取出即可

基本思想:

将数组分成两组A,B

如果这两组内的数据都是有序的那就very easy了

可以将A,B组各自再分成两组

依此类推

当分出来的小组只有一个数据时,可以认为这个小组内已经达到了有序

通过递归的分解数列再合并

合并有序数列的效率较高可以达到O(n)


import java.util.Arrays;

public class MergeSort {  
    /** 
     * 归并排序 
     * 简介:将两个(或两个以上)有序表合并成一个新的有序表 即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列 
     * 时间复杂度为O(nlogn) 
     * 稳定排序方式 
     * @param nums 待排序数组 
     * @return 输出有序数组 
     */  
    public static void sort(int[] nums, int low, int high) {  
        int mid = (low + high) / 2;  
        if (low < high) {  
            // 左边  
            sort(nums, low, mid);  
            // 右边  
            sort(nums, mid + 1, high);  
            // 左右归并  
            merge(nums, low, mid, high);  
        }  
    }   
    public static void merge(int[] nums, int low, int mid, int high) {
    	//根据当前merge的创建一个临时的数组
        int[] temp = new int[high - low + 1];  
        int i = low;// 左指针  
        int j = mid + 1;// 右指针  
        int k = 0;    
        // 把较小的数先移到新数组中  
        while (i <= mid && j <= high) {  
            if (nums[i] < nums[j]) {  
                temp[k++] = nums[i++];  
            } else {  
                temp[k++] = nums[j++];  
            }  
        }    
        // 把左边剩余的数移入数组  
        while (i <= mid) {  
            temp[k++] = nums[i++];  
        }    
        // 把右边边剩余的数移入数组  
        while (j <= high) {  
            temp[k++] = nums[j++];  
        }    
        // 把新数组中的数覆盖nums数组  
        for (int k2 = 0; k2 < temp.length; k2++) {  
            nums[k2 + low] = temp[k2];  
        }  
    }        
    // 归并排序的实现  
    public static void main(String[] args) {  
  
        int[] nums = { 2, 7, 8, 3, 1, 6, 9, 0, 5, 4 };  
  
        sort(nums, 0, nums.length-1);  
        System.out.println(Arrays.toString(nums));  
    }  
}  







Java单链表归并排序

概念归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用,归并排序将两个已排序的表合并成一个表。归并排序基本原理通过对若干个有...
  • bug_moving
  • bug_moving
  • 2017年02月24日 08:53
  • 1288

排序算法Java实现——归并排序

归并排序(也可以叫合并排序),其实归并排序的本质就是合并排序。 它是与插入排序、交换排序、选择排序不同的一类排序方法,不同之处在于: 它要求:待排序序列是由若干个有序子序列组成。 那么究竟什么是归并排...
  • singit
  • singit
  • 2017年04月25日 22:09
  • 743

归并排序的递归与非递归实现Java

public static int[] sort(int[] nums, int low, int high) { int mid = (low + high) / 2; ...
  • lll1204019292
  • lll1204019292
  • 2016年08月28日 16:20
  • 454

归并排序算法原理及JAVA实现

基本思想:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。递归形式的算法在形式上较简...
  • xuxurui007
  • xuxurui007
  • 2012年06月11日 23:10
  • 979

算法导论:归并排序java实现

这是归并排序的部分代码,个人认为归并排序作为算法课的前导算法算是一个比较难的问题因为他涉及到了我们都比较恐惧的递归运算。说到递归我们都是非常头疼的,但是递归较其他用迭代来实现的算法又算是理解起来比较简...
  • xidian_db
  • xidian_db
  • 2015年03月30日 16:33
  • 388

[排序算法]--归并排序的Java实现

归并排序(2-路归并):归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用,归并排序将两个已排序的表合并成一个表。 下面先看...
  • u010853261
  • u010853261
  • 2017年02月06日 16:14
  • 1158

【Java常用排序算法】归并排序(二路归并排序)

归并排序 二路归并排序 Java实现
  • donggua3694857
  • donggua3694857
  • 2017年02月27日 23:17
  • 1818

【排序算法】归并排序原理及Java实现

归并排序就是利用归并的思想实现的排序方法。而且充分利用了完全二叉树的深度特性,因此效率比较高。其基本原理如下:对于给定的一组记录,利用递归与分治技术将数据序列划分成为越来越小的半子表,在对半子表排序,...
  • jianyuerensheng
  • jianyuerensheng
  • 2016年04月27日 17:35
  • 13310

归并排序三种实现方法(递归、非递归和自然合并排序)

1.      递归实现归并排序 1)     基本思想: 将待排元素分成大小大致相同的2个子集,分别对2个子集合进行排序,最终将排好序的子集合合并 就会得到一个排好序的集合 即为所求 设归并排...
  • niuxiunan
  • niuxiunan
  • 2013年04月06日 23:28
  • 4456

选择,插入,希尔,快速,堆,归并排序六种排序方式的Java 实现和性能对比(付代码)

代码见:   https://github.com/Turtledove/EnHanceExercises/tree/master/EnHanceExercises/src 待续...
  • yunshuixiliu
  • yunshuixiliu
  • 2014年03月11日 14:49
  • 1388
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:归并排序!!--Java
举报原因:
原因补充:

(最多只允许输入30个字)