1 条题解
-
0
给大家分享一下归并排序的思路。
思路
归并排序是什么?分裂+合并。
首先把数组 平分成两半。
如可以把 分成 和 。
然后把 分成 和 。
接着把 分成 和 。
显然不能继续分下去,那就合并。
首先把首元素更小的 的数组的首元素提取出来,变成空数组后,也只能把 加入。得到了 。
然后以此类推, 变成了 ; 变成了 ,最后合并这两个子数组,首元素比较,合并顺序为 ( 表示提取 , 表示提取 )。
显然,归并排序运用了递归和分治的思想。
代码
#include <bits/stdc++.h> using namespace std; int n,a[100005],w[100005]; void merge(int l,int r){ if (l==r) return ; int mid=(l+r)>>1; merge(l,mid); merge(mid+1,r); int i=l,j=mid+1,cnt=l; while (i<=mid&&j<=r) if (a[i]<=a[j]) w[cnt++]=a[i++]; else w[cnt++]=a[j++]; while (i<=mid) w[cnt++]=a[i++]; while (j<=r) w[cnt++]=a[j++]; for (int k=l;k<=r;k++) a[k]=w[k]; } int main(){ cin>>n; for (int i=1;i<=n;i++) cin>>a[i]; merge(1,n); for (int i=1;i<=n;i++) cout<<a[i]<<" "; return 0; }
- 1
信息
- ID
- 5235
- 时间
- 1000ms
- 内存
- 256MiB
- 难度
- 2
- 标签
- 递交数
- 342
- 已通过
- 103
- 上传者