leetcode493. Reverse Pairs

Posted seyjs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode493. Reverse Pairs相关的知识,希望对你有一定的参考价值。

题目如下:

解题思路:本题要求的是数组每个元素和所有排在这个元素后面的元素的值的二倍做比较。我们可以先把数组所有元素的二倍都算出来,存入一个新的数组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
        

 

以上是关于leetcode493. Reverse Pairs的主要内容,如果未能解决你的问题,请参考以下文章

leetcode493. Reverse Pairs

leetcode493. Reverse Pairs

493. Reverse Pairs

493. Reverse Pairs(BST, BIT, MergeSort)

493 Reverse Pairs 翻转对

LeetCode Maximum Length of Pair Chain