给定一个数组 nums ,如果 i < j 且 nums[i] > 2*nums[j] 我们就将 (i, j) 称作一个重要翻转对。
你需要返回给定数组中的重要翻转对的数量。
示例 1:
输入: [1,3,2,3,1]
输出: 2
示例 2:
输入: [2,4,3,5,1]
输出: 3
注意:
- 给定数组的长度不会超过
50000
。 - 输入数组中的所有数字都在32位整数的表示范围内。
解题思路:类似归并排序,先统计,在排序。
class Solution {
public:
int reversePairs(vector<int>& nums) {
vector<int> temp(nums.size(), 0);
return mergeSort(nums, temp, 0, nums.size() - 1);;
}
int mergeSort(vector<int>& nums, vector<int>& temp, int left, int right) {
if(left >= right) return 0;
int mid = left + ((right - left) >> 1);
int count = mergeSort(nums, temp, left, mid) + mergeSort(nums, temp, mid+1,