码迷,mamicode.com
首页 > 其他好文 > 详细

【leetcode】493. Reverse Pairs

时间:2018-06-13 14:49:30      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:etc   turn   就是   new   IV   strong   一个   最大   rev   

题目如下:

技术分享图片

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

标签:etc   turn   就是   new   IV   strong   一个   最大   rev   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!