首页 > 编程语言 > 详细

数组中的逆序对

时间:2019-08-31 11:33:20      阅读:42      评论:0      收藏:0      [点我收藏+]

        在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数

private static long cnt = 0;
private static int[] temp;
public static int InversePairs(int[] array){
    temp = new int[array.length];
    mergeSort(array, 0, array.length - 1);
    return cnt;
}
private static void mergeSort(int[] nums, int l, int h){
    if (h - l < 1){
        return;
    }
    int m = l + (h - l) / 2;
    mergeSort(nums, l, m);
    mergeSort(nums, m + 1, h);
    merge(nums, l, m, h);
}
private static void merge(int[] nums, int l, int m, int h){
    int i = l;
    int j = m + 1;
    int k = l;
    while (i <= m || j <= h){
        if (i > m){
            temp[k] = nums[j++];
        }else if (j > h){
            temp[k] = nums[i++];
        }else if (nums[i] < nums[j]){
            temp[k] = nums[i++];
        }else{
            temp[k] = nums[j++];
            cnt += m - i + 1;
        }
        k++;
    }
    for (k = l; k <= h; k++){
        nums[k] = temp[k];
    }
}

 

数组中的逆序对

原文:https://www.cnblogs.com/earthhouge/p/11438074.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!