千家信息网

LeetCode如何找出数组中的逆序对

发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这篇文章主要介绍LeetCode如何找出数组中的逆序对,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目描述在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成
千家信息网最后更新 2025年12月03日LeetCode如何找出数组中的逆序对

这篇文章主要介绍LeetCode如何找出数组中的逆序对,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

题目描述

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

0 <= 数组长度 <= 50000

题目样例

示例

  • 输入: [7,5,6,4]
  • 输出: 5

题目思考

  1. 如何批量得到逆序对?

解决方案

思路
  • 一个比较容易想到的思路是双重循环, 暴力求逆序对, 但这样时间复杂度是 O(N^2), 根据数据规模肯定超时, 如何进行优化呢?
  • 如果我们能将问题进行分解, 先求出数组左右两部分的逆序对数目, 最后再一次遍历将分属两部分的逆序对(也即第一个数在左半部分, 第二个数在右半部分)也求出来并累加在一起, 这样就能优化时间复杂度到 O(NlogN), 这就是分治法的思想
  • 此时关键在于如何一次遍历就求得分属两部分的逆序对呢? 如果左右两部分是有序的就很好办了, 可以利用归并排序的思路, 双指针遍历, 哪边小就把哪边加入结果数组中. 如果是右侧小的话就意味着左侧剩余的数字都和当前右侧数字构成逆序对, 将对应的数目加入结果中即可.
  • 而左右部分有序正好也是归并排序的结果, 所以整个思路就是在归并排序的基础上加上逆序对的统计
  • 下面代码对必要的步骤有详细的解释, 方便大家理解
复杂度
  • 时间复杂度 O(NlogN): 使用了归并排序, 时间复杂度是( N+(N/2)*2+(N/4)*4+...+1*N = NlogN, 因为一共 logN 个乘积)
  • 空间复杂度 O(N): 归并排序需要用到临时数组, 长度为 N
代码
class Solution:
def reversePairs(self, nums: List[int]) -> int:
self.res = 0

def mergesort(s, e):
if s >= e:
return
m = (s + e) >> 1
# 先排序并统计左右部分
mergesort(s, m)
mergesort(m + 1, e)
# 使用临时数组存储排序好的左右部分
# 注意这里选择逆序存储, 是因为可以利用O(1)的pop操作得到最小的元素
# 当然这里也可以使用双端队列, 这样就无需逆序了
left = nums[s:m + 1][::-1]
right = nums[m + 1:e + 1][::-1]
for i in range(s, e + 1):
if not right or left and left[-1] <= right[-1]:
# 当前左侧数字更小或者右侧数字已经用完, 此时不构成逆序对
nums[i] = left.pop()
else:
# 当前右侧数字更小, 和剩余的左侧部分都构成逆序对
self.res += len(left)
nums[i] = right.pop()

mergesort(0, len(nums) - 1)
return self.res

以上是"LeetCode如何找出数组中的逆序对"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

逆序 数组 数字 部分 排序 复杂 复杂度 右侧 思路 时间 结果 题目 求出 有序 两个 个数 代码 内容 就是 数目 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 软件开发产品经理是做什么 apex和好友玩连接服务器超时 惠民软件开发公司王秀兰 莆田市微讯时代软件开发有限公司 服务器心跳检测的作用 数据库在应用统计学的应用 6句关于网络安全的诗 会员中心无法连接到服务器 大连东软网络安全工程师月薪 软件开发外包公司泄源码 对数据库安全要求包括下列 广州人工智能软件开发哪家便宜 我的世界服务器空岛 安卓机数据库 大学计算机网络技术与应用 linux服务器做好安全 数据库设计表格 济宁联想服务器代理哪个系列好 富士通服务器默认管理地址 怎么看数据库更新记录 数据库服务名怎么在电脑查 网络安全查杀漏洞台账 四十七岁应聘网络安全工程师 linux服务器配置 服务器主机能不能给别人用 贵阳方圆软件开发部 软件开发实施工作量评估 数据库授权和回收权限解释 服务器的线路主要有哪几种 重庆城管通软件开发公司
0