
题目描述
在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007
class Solution {
private:
long count=;
int *tmp;
public:
int InversePairs(vector<int> data) {
tmp = new int[data.size()]();
mergeSort(data, , data.size()-);
return count % ;
} void mergeSort(vector<int> &data, int l, int h){
if(h - l < )
return;
int m = l + (h-l) / ;
mergeSort(data, l, m);
mergeSort(data, m+, h);
merge(data, l, m, h);
} void merge(vector<int> &data, int l, int m, int h){
int i=l, j=m+, k=l;
while(i<=m && j<=h){
if(data[i] <= data[j])
tmp[k++] = data[i++];
else{
tmp[k++] = data[j++];
count += m-i+ ;
}
}
while(i<=m) tmp[k++] = data[i++];
while(j<=h) tmp[k++] = data[j++]; for(k=l; k<=h; ++k)
data[k] = tmp[k];
}
};