#include<iostream>
using namespace std;
int a[500100];
int t[500100];
long long ans;
void sort(int l,int r)
{
if(l==r) return ;
int mid=(l+r)/2;
sort(l,mid);
sort(mid+1,r);
int i,j,k;
i=l;j=mid+1;k=l;
while(i<=mid||j<=r)
{
if(j>r||(a[j]>a[i]&&i<=mid))
t[k++]=a[i++];
else {
t[k++]=a[j++];
ans+=mid+1-i;
}
}
for (i=l;i<=r;i++)
a[i]=t[i];
}
int main()
{
int n;
cin>>n;
while(n!=0){
for (int i=1;i<=n;i++)
cin>>a[i];
ans=0;
sort(1,n);
cout<<ans<<endl;
cin>>n;
}
return 0;
}
时间: 2024-12-23 08:44:10