一眼应该能看出来这道题朴素算法是冒泡排序,但是逆序对这类题要求复杂度小于等于O(nlogn), 因此可以用线段树,树状数组,归并排序之类的试试。
洛谷上有一样的题:逆序对 - 洛谷
AC代码(归并排序)
#include <bits/stdc++.h>
using namespace std;
int n,a[100001],b[100001];
long long ans;
void merge(int l,int r){
if(l==r)return;
int mid=l+r>>1;
merge(l,mid);
merge(mid+1,r);
//[l,i,mid][mid+1,j,r]
int i=l,j=mid+1,k=l;
while(i<=mid and j<=r){
if(a[i]<a[j])b[k++]=a[i++];
else b[k++]=a[j++],ans+=mid-i+1;//放入a[j],说明a[i,mid]都比a[j]大,产生mid-i+1个逆序对
}
while(i<=mid)b[k++]=a[i++];
while(j<=r)b[k++]=a[j++];
for(i=l;i<=r;++i)a[i]=b[i];
}
int main(){
ios::sync_with_stdio(false);
cin.tie(nullptr),cout.tie(nullptr);
cin>>n;
for(int i=1;i<=n;++i)
cin>>a[i];
merge(1,n);
cout<<ans;
return 0;
}