归并排序模板

方法:1将区间[l,r]分为[l,mid]和[mid+1,r]两个区间,其中mid=(l+r)/2;
2递归排序两个区间;
3合并两个区间;
模板:
定义原数组,和临时数组(储存每次合并好的两个小区间)
int a[N],tmp[N];
void merge_sort(int a[],int l,int r)
{
if(l>=r) return;//如果数组中只有一个数直接返回即可;
int mid=l+r>>1;
merge_sort(a,l,mid);merge_sort(a,mid+1,r);//递归处理两个区间(最后变成一个个的数,然后在两两合并);
int i=l,j=mid+1,k=0;
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=0;i<r;i++,j++) a[i]=tmp[j];//将临时数组里的数据存回原数组
}

参考acwing网站。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值