树状数组求逆序对
#include<iostream>
#include<cstdio>
#include<queue>
#include<set>
#include<algorithm>
#include<map>
#include<cstring>
#include<cmath>
using namespace std;
int v[100000+10];
int n;
int getsum(int x){
int sum=0;
while(x){
sum+=v[x];
x-=x&-x;
}
return sum;
}
void add(int x,int num){
while(x<=n){
v[x]+=num;
x+=x&-x;
}
}
int main(){
long long sum=0;
cin>>n;
for(int i=0;i<n;i++){
int num;
cin>>num;
sum+=i-getsum(num);
add(num,1);
}
cout<<sum;
return 0;
}