zoukankan      html  css  js  c++  java
  • 算法 逆序对

     题目:给定一个数组,选择数组中的逆序对

    arr={5,8,7,6,4}

    arr数组中的逆序对:{5,4}、{8,7}、{8,6}、{8,4}、{7,6}、{6,4}

    解题思路:如果通过遍历每个数,然后寻找逆序对,主要的时间复制度是O(N^2),通过归并排序的方法寻找逆序对的时间复制度O(NlogN)

    import java.util.Arrays;
    
    class Solution {
        public static int getReverse(int[] arr, int l, int r) {
            int reverseNum = 0;
            if (l < r) {
                int mid = (l + r) / 2;
                reverseNum += getReverse(arr, l, mid);
                reverseNum += getReverse(arr, mid + 1, r);
                reverseNum += meger(arr, mid, l, r);
            }
            return reverseNum;
        }
    
    
        public static int meger(int[] arr, int mid, int l, int r) {
            int[] temp = new int[r - l + 1];
            int reverseNum = 0;
    
            int i = l;
            int j = mid + 1;
            int k = 0;
    
            while (i <= mid && j <= r) {
                if (arr[i] <= arr[j]) {
                    temp[k++] = arr[i++];
                } else {
                    temp[k++] = arr[j++];
                    reverseNum += (mid - i + 1);
                }
            }
    
            while (i <= mid) {
                temp[k++] = arr[i++];
            }
            while (j <= r) {
                temp[k++] = arr[j++];
            }
            for (int k2 = 0; k2 < temp.length; k2++) {
                arr[k2 + l] = temp[k2];
            }
            return reverseNum;
        }
    
        public static void main(String[] args) {
    
            int[] nums = {5, 8, 7, 6, 4};
    
            int s = Solution.getReverse(nums, 0, nums.length - 1);
            System.out.println(Arrays.toString(nums));
            System.out.println(s);
        }
    };
  • 相关阅读:
    Java之ServiceLoader
    docker学习(3)--Dockfile详解
    docker学习(2)--基础命令
    docker学习(1)--基础概念
    dubbo学习(1)--简单的入门搭建实例
    Flume搭建及学习(基础篇)
    VM下--Linux根分区磁盘扩容
    Windows10下简单搭建zookeeper
    Windows10下搭建TensorFlow环境
    cmath库函数
  • 原文地址:https://www.cnblogs.com/googlemeoften/p/5849562.html
Copyright © 2011-2022 走看看