先上代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int a[N],tmp[N];
void merge_sort(int a[],int l,int r){
if(l>=r)return ;//返回条件
int mid=(l+r)/2;
merge_sort(a,l,mid);//先分
merge_sort(a,mid+1,r);
int k=1,i=l,j=mid+1;
while(i<=mid&&j<=r){//后合
if(a[i]<=a[j]) tmp[k++]=a[i++];
else tmp[k++]=a[j++];
}
while(i<=mid)tmp[k++]=a[i++];
while(j<=r)tmp[k++]=a[j++];
for(int i=l,j=1;i<=r;i++,j++){//及时保存
a[i]=tmp[j];
}
}
int main(){
int n;
cin>>n;
for(int i=1;i<=n;i++){
cin>>a[i];
}
merge_sort(a,1,n);
for(int i=1;i<=n;i++){
cout<<a[i];
}
}
快排与归并的不同:
快排是不断用一个随机值分成大的一份和小的一份,最后的结果就是排序好的数组;
归并排序是不断将数组二分,将二分的数组排好序之后合并;
归并排序为什么要tmp[]数组:
因为归并排序是先将原数组不断二分,所以需要一直用原数组,所以需要临时数组将结果保存;