zoukankan      html  css  js  c++  java
  • 51-数组中的逆序对

    题目:在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对。

    def inverse_pairs(arrys):
        if len(arrys)<2:
            return 0
    
        res = 0
        length = len(arrys)
        arrys_sort =sorted(arrys)
        for arr in arrys_sort:
            res += arrys.index(arr)
            arrys.remove(arr)
    
        return res
    

      注:官方给的方法是利用归并排序,时间复杂度为O(nlgn)。本文给出自己的方法,时间复杂度为O(n2),有待改进,但是实现很简洁。先对数组排序,利用内置的排序函数。然后依次遍历排序后的数组,并依次找到该数字在原数组中的索引,索引差值即为与该数组成逆序对的个数。

  • 相关阅读:
    UVa 1605
    UVa 120
    UVa 10384
    UVa 11694
    UVa 11846
    常用小函数
    【DP】:CF #319 (Div. 2) B. Modulo Sum
    类的无参方法
    类和对象
    七言
  • 原文地址:https://www.cnblogs.com/kingshine007/p/11502588.html
Copyright © 2011-2022 走看看