社区讨论
50分归并代码求调
P1908逆序对参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @lo2rtceo
- 此快照首次捕获于
- 2023/10/23 18:44 2 年前
- 此快照最后确认于
- 2023/10/23 18:44 2 年前
rt,用裸的归并排序改了改,WA了后10个点
CPP#include<bits/stdc++.h>
using namespace std;
int a[5000005];
int ans=0;
void msort(int s,int t)
{
int r[5000005];
if(s==t) return;
int m=(s+t)/2;
msort(s,m);
msort(m+1,t);
int i=s,j=m+1,k=s;
while(i<=m&&j<=t)
{
if(a[i]<=a[j])
{
r[k]=a[i];
k++; i++;
}
else
{
r[k]=a[j];
k++; j++;
ans+=m-i+1;
}
}
while(i<=m)
{
r[k]=a[i];
k++; i++;
}
while(j<=t)
{
r[k]=a[j];
k++; j++;
}
for(int i=s;i<=t;i++)
a[i]=r[i];
return ;
}
int main()
{
int b;
scanf("%d",&b);
for(int i=1;i<=b;i++)
scanf("%d",&a[i]);
msort(1,b);
printf("%d ",ans);
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...