Python数组中的逆序对

本文阅读 2 分钟
首页 Python笔记 正文

这道题可以这么想,我们要找到数组中的逆序对,可以看做对数据进行排序,需要交换数组中的元素的次数,但是防止相同大小的元素发生交换,因此需要选择一个稳定的排序方法,记录发生交换的次数。那么,基于比较的稳定的排序方法中,最快的方法就是归并了,所以直接按照归并排序的思路,将数组分解、合并、排序即可。但是需要注意的是,在常规归并排序的时候,如果前一个元素大于后一个元素,直接进行交换即可,只进行了一次操作,但是对于这道题来讲,对于每一次的归并段,我们选择从后向前遍历,前面的归并段的某一个数值left[i]如果大于后面的某一个数值right[j],因为在right自己独自排序的过程中,已经保证了right是有序的,所以j位置前面的数字全部小于right[j],所以在这里逆序对的个数就会是 j-start-length,其中start是整个数组的起点,length是left的长度,然后再进行交换。

  1. '''
  2. 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。
  3. 输入一个数组,求出这个数组中的逆序对的总数P。
  4. '''
  5. # -*- coding:utf-8 -*-
  6. class Solution:
  7. def InversePairs(self, data):
  8. length = len(data)
  9. if data == None or length <= 0:
  10. return 0
  11. copy = [0]*length
  12. for i in range(length):
  13. copy[i] = data[i]
  14. count = self.InversePairsCore(data, copy, 0, length-1)
  15. return count
  16. def InversePairsCore(self, data, copy, start, end):
  17. if start == end:
  18. copy[start] = data[start]
  19. return 0
  20. length = (end - start)//2
  21. left = self.InversePairsCore(copy, data, start, start+length)
  22. right = self.InversePairsCore(copy, data, start+length+1, end)
  23. # i初始化为前半段最后一个数字的下标
  24. i = start + length
  25. # j初始化为后半段最后一个数字的下标
  26. j = end
  27. indexCopy = end
  28. count = 0
  29. while i >= start and j >= start+length+1:
  30. if data[i] > data[j]:
  31. copy[indexCopy] = data[i]
  32. indexCopy -= 1
  33. i -= 1
  34. count += j - start - length
  35. else:
  36. copy[indexCopy] = data[j]
  37. indexCopy -= 1
  38. j -= 1
  39. while i >= start:
  40. copy[indexCopy] = data[i]
  41. indexCopy -= 1
  42. i -= 1
  43. while j >= start+length+1:
  44. copy[indexCopy] = data[j]
  45. indexCopy -= 1
  46. j -= 1
  47. return left + right + count
  48. # 使用数据的index进行求解
  49. def InversePairs2(self, data):
  50. if len(data) <= 0:
  51. return 0
  52. count = 0
  53. copy = []
  54. for i in range(len(data)):
  55. copy.append(data[i])
  56. copy.sort()
  57. i = 0
  58. while len(copy) > i:
  59. count += data.index(copy[i])
  60. data.remove(copy[i])
  61. i += 1
  62. return count
  63. s = Solution()
  64. print(s.InversePairs2([364,637,341,406,747,995,234,971,571,219,993,407,416,366,315,301,601,650,418,355,460,505,360,965,516,648,727,667,465,849,455,181,486,149,588,233,144,174,557,67,746,550,474,162,268,142,463,221,882,576,604,739,288,569,256,936,275,401,497,82,935,983,583,523,697,478,147,795,380,973,958,115,773,870,259,655,446,863,735,784,3,671,433,630,425,930,64,266,235,187,284,665,874,80,45,848,38,811,267,575]))
解压密码: detechn或detechn.com

免责声明

本站所有资源出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。

本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户自行鉴别,做一个有主见和判断力的用户。

本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。

Python第一个只出现一次的字符
« 上一篇 01-21
Python两个链表的第一个公共结点
下一篇 » 01-21

发表评论

惪特博客
  • 文章总数:
    18497 篇
  • 评论总数:
    53330 条
  • 标签总数:
    8873 个
  • 总浏览量:
    22814999 次
  • 最后更新:
    3月27日

最多点赞

随便看看

标签TAG