热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

归并排序运用——逆序对

归并排序运用——逆序对逆序对假设升序为默认的序列,在一个数组中,数组的任意一对数字逆序即inum[j],则称这一数对为逆序数对
归并排序运用——逆序对

逆序对

假设升序为默认的序列,在一个数组中,数组的任意一对数字逆序即inum[j],则称这一数对为逆序数对

题目

给定一个数组,求该数组的逆序数对

数组中的逆序对

示例:

输入:
7 5 6 4
5

思路

第一想法是暴力求解,暴力的时间复杂度是O(n^2),会超时

采用归并排序来优化时间复杂度

归并排序是通过将数组分治,再将两个有序数组合并,那么在有序数组合并的时候就可以展开操作了,具体怎么做呢?

假设两个有序的数组:3 5 7 9 | 2 4 6 8第一步合并:
2 3 5 7 9 | 4 6 8操作开始:当插入2的时候,可以肯定的是2小于[3 5 7 9]中的任何一个数字
那么2的逆序数对就有4个,结果+4第二步合并
2 3 5 7 9 | 4 6 8操作开始:当插入3的时候,可以肯定的是3小于[4 5 6]中的任何一个数字
而5 7 9 的位置也在3后面,所以逆序对数为0.结果不变第三步合并
2 3 45 7 9 | 6 8操作开始:当插入2的时候,可以肯定的是4小于[5 7 9]中的任何一个数字
那么2的逆序数对就有3个,结果+3



结果:
2 3 4 5 6 7 8 9
这时候数组有序了,逆序对数是10这时候在将 2 3 4 5 6 7 8 9和另一个数组1 2 3 4 5 6 7 8 9合并
遵循上面的操作,得出 逆序对数结果 + 10 + 1 2 3 4 5 6 7 8 9]的逆序对结果0
就是两个数组合并后数组的逆序对数
ps(3 5 7 9 和 2 4 6 8的逆序对数均为0)

示例代码

class Solution {public int reversePairs(int[] nums) {
int len &#61; nums.length;if(len<2){return 0;}int[] temp &#61; new int[len];return mergeSort(0 , len-1 , temp , nums);}private int mergeSort(int left, int right, int[] temp, int[] nums) {if(left&#61;&#61;right){return 0;}int mid &#61; left&#43;(right-left)/2;int left_ans &#61; mergeSort(left , mid , temp , nums);int right_ans &#61; mergeSort(mid&#43;1 , right , temp , nums);int merge_ans &#61; mergeArray(left , mid , right , temp ,nums);return left_ans&#43;right_ans&#43;merge_ans; //左数组的逆序对数&#43;合并计算的逆序对数&#43;右数组的逆序对数}private int mergeArray(int left, int mid, int right, int[] temp, int[] nums) {int count &#61; 0;System.arraycopy(nums , 0 , temp , 0 , nums.length);int i &#61; left;int j &#61; mid&#43;1;for (int k &#61; left; k <&#61;right ; k&#43;&#43;) {if(i&#61;&#61;mid&#43;1){nums[k]&#61;temp[j];j&#43;&#43;;}else if(j&#61;&#61;right&#43;1){nums[k] &#61; temp[i];i&#43;&#43;;}else if(temp[i]<&#61;temp[j]){nums[k] &#61; temp[i];i&#43;&#43;;}else {nums[k] &#61; temp[j];j&#43;&#43;;count&#43;&#61;(mid-i&#43;1); //最重要的计数操作}}return count;}
}

类似题目


  • 翻转对
  • 区间和的个数

推荐阅读
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 本文介绍了在Python张量流中使用make_merged_spec()方法合并设备规格对象的方法和语法,以及参数和返回值的说明,并提供了一个示例代码。 ... [详细]
  • C语言常量与变量的深入理解及其影响
    本文深入讲解了C语言中常量与变量的概念及其深入实质,强调了对常量和变量的理解对于学习指针等后续内容的重要性。详细介绍了常量的分类和特点,以及变量的定义和分类。同时指出了常量和变量在程序中的作用及其对内存空间的影响,类似于const关键字的只读属性。此外,还提及了常量和变量在实际应用中可能出现的问题,如段错误和野指针。 ... [详细]
author-avatar
吴秋仪6_913
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有