4.3_8种常用排序算法4(归并排序)

【归并排序】

【归并排序实例】

package com.sort.demo4;

import java.util.Arrays;

/**
 * 归并排序
 */
public class MergeSort {

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

    public static void  mergeSort(int[] arr,int low, int high) {
        int middle = (high+low)/2;
        if(low<high) {
            //处理左边
            mergeSort(arr, low, middle);
            //处理右边
            mergeSort(arr, middle + 1, high);
            //归并
            merge(arr, low, middle, high);
        }
    }

    public static void merge(int[] arr,int low,int middle, int high) {
        //用于存储归并后的临时数组
        int[] temp = new int[high-low+1];
        //记录第一个数组中需要遍历的下标
        int i= low;
        //记录第二个数组中需要遍历的下标
        int j =middle+1;
        //用于记录在临时数组中存放的下边
        int index = 0;
        //遍历两个数组去除小的数字,放入临时数组中
        while (i<=middle && j<=high){
            //第一个数组的数据更小
            if(arr[i]<=arr[j]){
                //把小的数据放入临时数组中
                temp[index]=arr[i];
                //让下标向后移一位
                i++;
            }else {
                temp[index] = arr[j];
                j++;
            }
            index++;
        }
        //处理多余的数据
        while (j<=high){
            temp[index] = arr[j];
            j++;
            index++;
        }
        while (i<=middle){
            temp[index]=arr[i];
            i++;
            index++;
        }
        //把临时数组中的数据重新存入原数组
        for (int k=0;k<temp.length;k++){
            arr[k+low] = temp[k];
        }
    }


}

 

posted @ 2019-03-26 17:30  HigginCui  阅读(435)  评论(0编辑  收藏  举报