Java教程

归并排序java实现

本文主要是介绍归并排序java实现,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

import java.util.Scanner;
public class Main {
//该数组用来临时存放左半边和右半边数组的数据
static int[] temp=new int[100010];
public static void merge_sort(int q[],int l,int r) {
if(l>=r){
return;
}
//1.用数组中间点将数组分为左右两边
int mid=l+r>>1;
//用两个指针分别指向左半边第一个数和右半边第一个数
int i=l,j=mid+1;
//2.递归处理左半边和右半边
merge_sort(q,l,mid);
merge_sort(q,mid+1,r);
//3.合并
int k=0;//判断temp数组取第几个值
while(i<=mid&&j<=r){
//将左半边和右半边小的值放到temp数组里
if(q[i]<=q[j]){
temp[k++]=q[i++];
}
else{
temp[k++]=q[j++];
}

}
//将剩下的数组添加到temp数组
while(i<=mid){
temp[k++]=q[i++];
}
while(j<=r){
temp[k++]=q[j++];
}
//将temp数组值复制到原数组中
for(int z=l,u=0;z<=r;z++,u++){
q[z]=temp[u];
}
}

public static void main(String[] args) {
Scanner scan=new Scanner(System.in);
int n=scan.nextInt();
int[] arr=new int [n];
for(int i=0;i<n;i++) {
arr[i]=scan.nextInt();
}
merge_sort(arr,0,n-1);
for(int i=0;i<n;i++) {
System.out.print(arr[i]+" ");
}
}
}

这篇关于归并排序java实现的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!