归并排序!!--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归并排序

  • 2016年07月02日 23:51
  • 12KB
  • 下载

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

1、分治法 许多有用的算法在结构上是递归的:为了解决一个给定的问题,算法一次或多次递归地调用其自身以解决紧密相关的若干子问题。这些算法典型地遵循分治法的思想:将原问题分解为几个规模较小但类似于原问题的...

自然归并排序java版

  • 2017年11月06日 13:19
  • 3KB
  • 下载

java实现归并排序

  • 2013年04月08日 16:23
  • 666KB
  • 下载

归并排序MergeSort(Java)

归并排序思想:先将数组中的每两个进行合并并且在合并的过程中进行排序,然后每四个进行合并。一直到数组合并完成。 例如上图中:要对数组中的元素:80、30、60、20、10、60、50、70进行排序,先...

图解归并排序算法(java版)

归并排序:采用分治法的思想(递归),将整个数组序列分成两个序列,再讲两个序列分成各自的子序列,采用递归的思想解决一个个的子问题。归并排序的时间复杂度:O(n*lgn) 归病排序的空间复杂度:O(n)...

插入排序和归并排序的实现java

  • 2011年05月18日 16:20
  • 13KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:归并排序!!--Java
举报原因:
原因补充:

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