note | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|
|
#考点/时间空间效率的平衡 #难度/5 牛客网
在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数 P。并将 P 对 1000000007 取模的结果输出。 即输出 P%1000000007
输入描述:
题目保证输入的数组中没有的相同的数字
数据范围:
对于%50的数据,size<=10^4
对于%75的数据,size<=10^5
对于%100的数据,size<=2*10^5
示例1
输入
1,2,3,4,5,6,7,0
输出
7
function InversePairs(data) {
if (!data || data.length < 2) {
return 0;
}
var copy = data.concat(),
count = 0;
count = MergeSort(data, copy, 0, data.length - 1);
return count % 1000000007;
}
function MergeSort(data, copy, start, end) {
if (end === start) {
return 0;
}
var len = Math.floor((end - start) / 2);
var left = MergeSort(copy, data, start, start + len);
var right = MergeSort(copy, data, start + len + 1, end);
var count = 0;
var p = start + len,
q = end,
copyIndex = end;
while (p >= start && q >= start + len + 1) {
if (data[p] > data[q]) {
count += q - start - len;
copy[copyIndex--] = data[p--];
} else {
copy[copyIndex--] = data[q--];
}
}
while (p >= start) {
copy[copyIndex--] = data[p--];
}
while (q >= start + len + 1) {
copy[copyIndex--] = data[q--];
}
return left + right + count;
}