* @Description 数组中的逆序对
* @问题: 题目描述在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007输入描述:题目保证输入的数组中没有的相同的数字

数据范围:

对于%50的数据,size<=10^4

对于%75的数据,size<=10^5

对于%100的数据,size<=2*10^5

示例1输入复制1,2,3,4,5,6,7,0输出
数组中的逆序对

思路分析:
我们的第一反应是顺序扫描整个数组。每扫描到一个数组的时候,逐个比较该数字和它后面的数字的大小。如果后面的数字比它小,则这两个数字就组成了一个逆序对。假设数组中含有n个数字。由于每个数字都要和O(n)这个数字比较,因此这个算法的时间复杂度为O(n^2)。
我们以数组{7,5,6,4}为例来分析统计逆序对的过程。每次扫描到一个数字的时候,我们不拿ta和后面的每一个数字作比较,否则时间复杂度就是O(n^2),因此我们可以考虑先比较两个相邻的数字。
 
(a) 把长度为4的数组分解成两个长度为2的子数组;
(b) 把长度为2的数组分解成两个成都为1的子数组;
(c) 把长度为1的子数组 合并、排序并统计逆序对 ;
(d) 把长度为2的子数组合并、排序,并统计逆序对;
在上图(a)和(b)中,我们先把数组分解成两个长度为2的子数组,再把这两个子数组分别拆成两个长度为1的子数组。接下来一边合并相邻的子数组,一边统计逆序对的数目。在第一对长度为1的子数组{7}、{5}中7大于5,因此(7,5)组成一个逆序对。同样在第二对长度为1的子数组{6}、{4}中也有逆序对(6,4)。由于我们已经统计了这两对子数组内部的逆序对,因此需要把这两对子数组 排序 如上图(c)所示, 以免在以后的统计过程中再重复统计。
接下来我们统计两个长度为2的子数组子数组之间的逆序对。合并子数组并统计逆序对的过程如下图如下图所示。
我们先用两个指针分别指向两个子数组的末尾,并每次比较两个指针指向的数字。如果第一个子数组中的数字大于第二个数组中的数字,则构成逆序对,并且逆序对的数目等于第二个子数组中剩余数字的个数,如下图(a)和(c)所示。如果第一个数组的数字小于或等于第二个数组中的数字,则不构成逆序对,如图b所示。每一次比较的时候,我们都把较大的数字从后面往前复制到一个辅助数组中,确保辅助数组(记为copy) 中的数字是递增排序的。在把较大的数字复制到辅助数组之后,把对应的指针向前移动一位,接下来进行下一轮比较。
过程:先把数组分割成子数组,先统计出子数组内部的逆序对的数目,然后再统计出两个相邻子数组之间的逆序对的数目。在统计逆序对的过程中,还需要对数组进行排序。如果对排序算法很熟悉,我们不难发现这个过程实际上就是归并排序。
代码实现:

package LG.nowcoder;/*** @Author liguo* @Description 数组中的逆序对* @问题: 题目描述* 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007* 输入描述:* 题目保证输入的数组中没有的相同的数字* <p>* 数据范围:* <p>* 对于%50的数据,size<=10^4* <p>* 对于%75的数据,size<=10^5* <p>* 对于%100的数据,size<=2*10^5* <p>* 示例1* 输入* 复制* 1,2,3,4,5,6,7,0* 输出* 复制* @思路:* @Data 2018-09-24 0:57*/
public class Solution27 {int cnt;public int InversePairs(int[] array) {cnt = 0;if (array != null)mergeSortUp2Down( array, 0, array.length - 1 );return cnt;}/** 归并排序(从上往下)*/public void mergeSortUp2Down(int[] a, int start, int end) {if (start >= end)return;int mid = (start + end) >> 1;mergeSortUp2Down( a, start, mid );mergeSortUp2Down( a, mid + 1, end );merge( a, start, mid, end );}/** 将一个数组中的两个相邻有序区间合并成一个*/public void merge(int[] a, int start, int mid, int end) {int[] tmp = new int[end - start + 1];int i = start, j = mid + 1, k = 0;while (i <= mid && j <= end) {if (a[i] <= a[j])tmp[k++] = a[i++];else {tmp[k++] = a[j++];cnt += mid - i + 1;}}while (i <= mid)tmp[k++] = a[i++];while (j <= end)tmp[k++] = a[j++];for (k = 0; k < tmp.length; k++)a[start + k] = tmp[k];}
}}

数组中的逆序对,归并排序

转载于:https://www.cnblogs.com/liguo-wang/p/9694504.html

算法:数组中的逆序对相关推荐

  1. 数据结构与算法--数组中的逆序对

    题目:在数组中的两个数字如果签名一个数字大于后面的数组,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数. 案例:输入数组{7,5,6,4}中一共有5个逆序对分别是{7,6},{ ...

  2. 【算法题目】数组中的逆序对

    题目来源:<剑指offer>面试题36 题目:在数组中的两个数字如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这两个数组中的逆序对的总数.例如数组{7,5, ...

  3. 《剑指offer》-- 数组中的逆序对、最小的K个数、从1到n整数中1出现的次数、正则表达式匹配、数值的整数次方

    一.数组中的逆序对: 1.题目: 数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出 ...

  4. c语言数组求逆序对,LeetCode 面试题51. 数组中的逆序对

    面试题51. 数组中的逆序对 题目来源:https://leetcode-cn.com/problems/shu-zu-zhong-de-ni-xu-dui-lcof/ 题目 在数组中的两个数字,如果 ...

  5. 剑指offer之【数组中的逆序对】

    题目: 数组中的逆序对 链接: https://www.nowcoder.com/practice/96bd6684e04a44eb80e6a68efc0ec6c5?tpId=13&tqId= ...

  6. 【剑指offer】_12 数组中的逆序对

    题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%1000 ...

  7. vb.net中递归退到最外层_数组中的逆序对

    题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%1000 ...

  8. 面试题36:数组中的逆序对

    题目:在数组中的两个数字如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数.例如,有一个数组为Array[0..n] 其中有元素a[i],a[j]. ...

  9. 剑指offer面试题[36]-数组中的逆序对

    题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%1000 ...

最新文章

  1. 海量大数据大屏分析展示一步到位:DataWorks数据服务对接DataV最佳实践
  2. GCC跟NASM联合编译
  3. 为什么每次关机都要关闭mysql_在机器关机时关闭mysql服务实例
  4. apache搭建的 webserver下载站点
  5. Tensorflow中placeholder传入值与feed_dict喂食器的联系与用法
  6. 通过GitHub Pages创建个人主页
  7. Java行为参数化(一)
  8. 设计模式002:简单工厂模式
  9. html剧场座位设计图,如何设计剧院座位,21个细部案例
  10. 双屏怎么快速切换鼠标_双屏触摸一体机功能特点解析
  11. jdk和tomcat
  12. CS229 Lecture 12
  13. arangoDB基本操作
  14. AAAI 2020 | 清华大学:借助BabelNet构建多语言义原知识库
  15. request、response
  16. 完爆面试官!2021Java高频精选面试题讲解
  17. 原生js实现购物车添加删除商品、计算价格功能
  18. 我们需要多大的电视?
  19. 淘宝数据库OceanBase SQL编译器部分 源码阅读--解析SQL语法树
  20. 张勋说:钢渣处理工艺流程图及解析

热门文章

  1. JavaScript基础---匿名函数
  2. JAVA设计模式之【外观模式】
  3. Android实现登录
  4. 在JavaScript中使用json.js:Ajax项目之POST请求(异步)
  5. 列表操作 - C#开发人员
  6. Bootstrap页面布局17 - BS选项卡
  7. Web.py Cookbook 简体中文版 - 保存上传的文件
  8. Hadoop编译打包记录
  9. vue-cli@4安装Element-ui
  10. Django echarts初试随笔