JAVA合并排序(归并排序)代码-及实现

已80,20,6,45,35,19,100,64为例

合并排序

  • JAVA实现代码

import java.util.Arrays;

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

    public static void main(String[] args) {
        int[] arr = new int[]{80,20,6,45,35,19,100,64};
        int left = 0;
        int right=arr.length-1;
        int[] tem = Arrays.copyOf(arr,arr.length);
        print(arr);
        mergeSort(arr,left,right,tem);
        print(arr);
    }

    public static void mergeSort(int[] arr , int left ,int right , int[] tem){
        if(right-left<1){
            return;
        }
        int mid = left + (right-left)/2;
        mergeSort(arr,left,mid,tem);
        mergeSort(arr,mid+1,right,tem);
        merge(arr,left,mid,right,tem);
    }

    private static void merge(int[] arr, int left, int mid, int right, int[] tem) {
        int index=0;
        int l=left,r=mid+1;
        while(l<=mid && r<=right){
            if(arr[l]<arr[r]){
                tem[index++]=arr[l++];
            }else{
                tem[index++]=arr[r++];
            }
        }
        while(l<=mid){
            tem[index++]=arr[l++];
        }
        while(r<=right){
            tem[index++]=arr[r++];
        }

        for(int i=0;i<(right-left+1);i++){
            arr[left+i]=tem[i];
        }
    }

    private static void print(int[] arr){
        for (int i : arr){
            System.out.print(i+"\t");
        }
        System.out.println();
    }
}

代码执行过程

执行过程

作者QQ:420318184
邮箱:fy@0fy0.com

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

飛之宇

你的支持是我们的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值