社区讨论
问
灌水区参与者 4已保存回复 5
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 5 条
- 当前快照
- 1 份
- 快照标识符
- @lzlyegyl
- 此快照首次捕获于
- 2024/08/09 08:13 2 年前
- 此快照最后确认于
- 2024/08/09 09:26 2 年前
两个50万int数组占多大空间
为什么我这个代码(P1908)交上去会MLE
CPP#include<iostream>
using namespace std;
int a[500001],b[500001],n;
long long res=0;
void mergeSort(int l,int r)
{
int mid=(l+r)>>1;
if(l==r)
return;
mergeSort(l,mid);
mergeSort(mid+1,r);
int i=l,j=mid+1,k=l;
while(i<=mid&&j<=r)
{
if(a[i]>a[j])
{
b[k]=a[j];
k++;
res+=mid-i+1;
j++;
}
else
{
b[k]=a[i];
i++;
k++;
}
}
while(i<=mid)
{
b[k]=a[i];
i++;
k++;
}
while(j<=r)
{
b[k]=a[j];
j++;
k++;
}
for(i=l;i<=r;i++)
a[i]=b[i];
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr);
cout.tie(nullptr);
for(int i=1;i<=n;i++)
cin>>a[i];
mergeSort(1,n);
cout<<res;
return 0;
}
回复
共 5 条回复,欢迎继续交流。
正在加载回复...