逆序对个数

题目

一个数列,如果左边的数大,右边的数小,则称这两个数为一个逆序对。求出一个数列中右多少个逆序对。

解法1

暴力遍历所有可能的数对。

java 复制代码
package com.company;

public class Test17 {
    public static void main(String[] args) {
        int[] arr={1	,4	,9,	6	,2,	8,	7	,3	,5};

        int count=0;
        for (int i = 0; i < arr.length; i++) {
            for (int j = i+1; j < arr.length; j++) {
                if(arr[i]>arr[j]){
                    count++;
                }
            }
            System.out.println(count);
        }
        System.out.println(count);
    }
}

解法2

在归并排序的过程中,如果左半部分的数大于右半部分的数,则出现了逆序对,并且不止一个。

java 复制代码
package com.company;

import java.util.Arrays;

public class Test18 {
    public static int count=0;
    public static void main(String[] args) {
        int[] arr={1	,4	,9,	6	,2,	8,	7	,3	,5};

        sort(arr,0,arr.length-1);
        System.out.println(Arrays.toString(arr));
        System.out.println(count);
    }
    public static void sort(int[] arr,int fromIndex,int toIndex){
        if(toIndex-fromIndex<=0){
            return;
        }
        int mid=(fromIndex+toIndex)/2;
        sort(arr,fromIndex,mid);
        sort(arr,mid+1,toIndex);
        int[] help=new int[toIndex-fromIndex+1];
        int i=mid,j=toIndex,k=help.length-1;
        while(i>=fromIndex && j>=mid+1){
            if(arr[i]>arr[j]){
                count=count+(j-mid);

                help[k]=arr[i];
                k--;
                i--;
            }else{
                help[k]=arr[j];
                k--;
                j--;
            }
        }
        System.out.println(count);
        while(i>=fromIndex){
            help[k]=arr[i];
            k--;
            i--;
        }
        while(j>=mid+1){
            help[k]=arr[j];
            k--;
            j--;
        }
        i=fromIndex;
        k=0;
        for (int l = fromIndex; l <=toIndex ; l++) {
            arr[l]=help[l-fromIndex];
        }
    }
}
相关推荐
win水5 分钟前
数据结构(初阶)(一)----算法复杂度
c语言·数据结构·算法
I_Am_Me_6 分钟前
【专题三:穷举vs暴搜vs深搜vs回溯vs剪枝】46. 全排列
算法·机器学习·剪枝
I_Am_Me_7 分钟前
【专题二 二叉树中的深搜】814. 二叉树剪枝
算法·剪枝
ekskef_sef10 分钟前
Nginx—Rewrite
java·数据库·nginx
我想吃余13 分钟前
高阶C语言|库函数qsort的使用以及用冒泡排序实现qsort的功能详解
c语言·开发语言·数据结构·算法
星迹日16 分钟前
数据结构:二叉树
java·数据结构·经验分享·二叉树·
道剑剑非道22 分钟前
QT开发技术 【基于TinyXml2的对类进行序列化和反序列化】 二
java·数据库·qt
码上艺术家34 分钟前
手摸手系列之 Java 通过 PDF 模板生成 PDF 功能
java·开发语言·spring boot·后端·pdf·docker compose
earthzhang20211 小时前
《深入浅出HTTPS》读书笔记(29):TLS/SSL协议
开发语言·网络协议·算法·https·ssl
Victoria.a1 小时前
二叉树和堆
数据结构·算法