关闭

归并排序!!--Java

标签: 归并排序
105人阅读 评论(0) 收藏 举报
分类:

归并排序!!


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

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

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

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

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

基本思想:

将数组分成两组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));  
    }  
}  







0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:52669次
    • 积分:1550
    • 等级:
    • 排名:千里之外
    • 原创:98篇
    • 转载:52篇
    • 译文:0篇
    • 评论:12条
    最新评论