首页 > 其他 > 详细

【leetcode】493. Reverse Pairs

时间:2018-06-13 13:29:12      阅读:105      评论:0      收藏:0      [点我收藏+]

题目如下:

技术分享图片

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

 

【leetcode】493. Reverse Pairs

原文:https://www.cnblogs.com/seyjs/p/9176720.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!