ToB企服应用市场:ToB评测及商务社交产业平台

标题: 每日算法之数组中的逆序对 [打印本页]

作者: 农民    时间: 2022-12-22 16:02
标题: 每日算法之数组中的逆序对
JZ51 数组中的逆序对

题目

在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P mod 1000000007
方法1:暴力

思路

算法实现
两个for循环,如果前面的数大于后面的计数加1即可
问题
当输入数过大时,需要的时间会很长,所以此方法不行
代码
  1. package mid.JZ51数组中的逆序对;
  2. import java.util.ArrayList;
  3. public class Solution {
  4.      public int InversePairs1(int[] array) {
  5.             int k = 1000000007;
  6.             if (array.length <= 1) return 0;
  7.             int res = 0;
  8.    
  9.             for (int i = 1; i < array.length; i++) {
  10.                 for (int j = i - 1; j >= 0; j--) {
  11.                     if (array[i] < array[j])
  12.                         res++;
  13.                 }
  14.             }
  15.             return res % k;
  16.         }
  17. }
复制代码
方法2 归并排序思想

思路

代码

[code]package mid.JZ51数组中的逆序对;import java.util.Arrays;public class Solution {    /**     * 分治     *     * @param array     * @return     */    public int count = 0;    public int InversePairs(int[] array) {        divMerge(array, 0, array.length-1);        return count;    }    public void divMerge(int[] array, int left, int right) {        if (left >= right) return;        int mid = left + (right - left) / 2;        //分左边        divMerge(array, left, mid);        //分右边        divMerge(array, mid + 1, right);        //合并        int i = left;        int j = mid + 1;        //临时数组        int[] tmp = new int[right - left + 1];        int k = 0;        while (i




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4