合并排序
合并排序是采用分治法的一种非常典型的应用,它是建立在归并操作上的一种有效的排序算法。合并排序是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分成为若干个子序列,每个子序列是有序的,然后再把有序的子序列合并为整体有序的序列。将已有序的子序列合并,得到完全有序的序列,即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。合并排序也称为归并排序。
public class GuiBing {
public static void main(String[] args) {
// long st = System.currentTimeMillis();
GB gb=new GB();
gb.init();
gb.show();
// long et = System.currentTimeMillis();
// System.out.println();
// System.out.println(et-st);
}
}
class GB {
int [] r= {80,18,72,95,60,36,38,1}; //待排序序列
int [] r1=new int[r.length]; //记录已排序序列
int s=0; //序列第一个下标,第一个为0
int t=r.length-1; //序列最后一个下标
void init(){
MergeSort(r,r1,s,t);
}
void MergeSort(int r[],int r1[],int s,int t){
int m;
if(s==t)
r1[s]=r[s];
else {
m=(s+t)/2;
MergeSort(r,r1,s,m); //归并前半个子序列
MergeSort(r,r1,m+1,t); //归并后半个子序列
Merge(r1,r,s,m,t); //合并两个已排序的子序列
}
}
int Merge(int r1[],int r[],int s,int m,int t){
for(int a=s;a<=t;a++) {
r[a]=r1[a];
}
int i=s;
int j=m+1;
int k=s;
while(i<=m && j<=t) { //取较小的放入r1[k]
if(r[i]<=r[j])
r1[k++]=r[i++];
else
r1[k++]=r[j++];
}
if(i<=m) { //若第一个子序列没处理完,则进行收尾处理
while(i<=m)
r1[k++]=r[i++];
}
else { //若第二个子序列没处理完,则进行收尾处理
while(j<=t)
r1[k++]=r[j++];
}
return 0;
}
void show() {
System.out.printf("\n");
for(int i=0;i<r1.length;i++) {
System.out.printf("%d ",r1[i]);
}
}
}
结果:
1 18 36 38 60 72 80 95