题目如下:
解题思路:本题要求的是数组每个元素和所有排在这个元素后面的元素的值的二倍做比较。我们可以先把数组所有元素的二倍都算出来,存入一个新的数组newlist,并按升序排好。而后遍历nums数组的每个元素i,通过二分查找的方法在newlist中找到值比i小的元素中下标最大的那个(记为inx),那么符合条件i元素的reverse paris就是inx,累计所有的inx即可得到结果。
代码如下:
class Solution(object): def reversePairs(self, nums): """ :type nums: List[int] :rtype: int """ res = 0 nl = [] for i in nums: nl.append(2*i) nl.sort() res = 0 import bisect for i in nums: inx = bisect.bisect_left(nl,2*i) del nl[inx] inx = bisect.bisect_left(nl, i) res += inx return res