给定一个1-N的排列A1, A2, ... AN,如果Ai和Aj满足i < j且Ai > Aj,我们就称(Ai, Aj)是一个逆序对。
求A1, A2 ... AN中所有逆序对的数目。
Input
第一行包含一个整数N。
第二行包含N个两两不同整数A1, A2, ... AN。(1 <= Ai <= N)
对于60%的数据 1 <= N <= 1000
对于100%的数据 1 <= N <= 100000
Output
一个整数代表答案
Sample Input
5 3 2 4 5 1
Sample Output
5
#include <iostream>
using namespace std;
const long N = 100000;
long a[N],tmp[N];
long flag;
void Merge(long l,long m,long r)
{
long i = l;
long j = m + 1;
long k = l;
while(i <= m && j <= r)
{
if(a[i] > a[j])
{
tmp[k++] = a[j++];
flag+=m-i+1;
}
else tmp[k++