社区讨论

灌水区参与者 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 条回复,欢迎继续交流。

正在加载回复...