码迷,mamicode.com
首页 > 编程语言 > 详细

Java实现归并排序

时间:2016-05-13 09:18:59      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:

package Sort;

import java.util.Arrays;

public class MergeSort {

    public static void merge(int[] list, int low, int mid, int high) {
        
        int[] temp = new int[high - low + 1];  
        int i = low;
        int j = mid + 1;  
        int k = 0;  
  
        while (i <= mid && j <= high) {  
            if (list[i] < list[j]) {  
                temp[k++] = list[i++];  
            } else {  
                temp[k++] = list[j++];  
            }  
        }  
        
        while (i <= mid) {  
            temp[k++] = list[i++];  
        }  
        
        while (j <= high) {  
            temp[k++] = list[j++];  
        }  
  
        for (int k2 = 0; k2 < temp.length; k2++) {  
            list[k2 + low] = temp[k2];  
        }  
        
    }
    
    public static int[] sort(int[] list, int low, int high) {
        int mid = (low + high) / 2;  
        if (low < high) {  
            sort(list, low, mid);  
            sort(list, mid + 1, high);  
            merge(list, low, mid, high);  
        }  
        
        return list;
    }

    
    public static void main(String[] args) {
        int[] list = {5,4,3,2,1,6,8,7};
        System.out.println(Arrays.toString(sort(list,0,list.length-1)));        
    }

}

 

Java实现归并排序

标签:

原文地址:http://www.cnblogs.com/finalboss1987/p/5485650.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!