【InversionCount 逆序对数 + MergeSort】
来源:互联网 发布:中国最大的unity3d论坛 编辑:程序博客网 时间:2024/05/30 04:38
Definition of Inversion: Let (A[0], A[1] ... A[n], n <= 50) be a sequence of n numbers. If i < j and A[i] > A[j], then the pair (i, j) is called inversion of A.
Example:Count(Inversion({3, 1, 2})) = Count({3, 1}, {3, 2}) = 2
思路,如果用brute force,则O(n^2),借用合并排序里面的合并步骤里的思路
import java.util.Arrays;public class MergeSort {static int InversionCount = 0;public static void main(String[] args) {int[] array = {3,1,2,5,4,7,6};MergeSort(array, 0, array.length-1);System.out.println(InversionCount);System.out.println(Arrays.toString(array));}public static void MergeSort(int[] array, int lhs, int rhs) {if (lhs < rhs) {int mid = lhs + ((rhs - lhs)>>1);MergeSort(array, lhs, mid);MergeSort(array, mid+1, rhs);Merge(array, lhs, mid, rhs);}}public static void Merge(int[] array, int lhs, int mid, int rhs) {int[] tmp = new int[rhs-lhs+1];int i = lhs, j = mid+1;int k = 0;while(i <= mid && j <= rhs){if (array[i] > array[j]) {InversionCount += mid-i+1;tmp[k++] = array[j++];}else {tmp[k++] = array[i++];}}while(i <= mid){tmp[k++] = array[i++];}while(j <= rhs){tmp[k++] = array[j++];}for (i = 0; i < k; i++) {array[i+lhs] = tmp[i];}tmp = null;}}
0 0
- 【InversionCount 逆序对数 + MergeSort】
- 逆序对数
- 逆序对数
- 逆序对数
- MergeSort 求逆序数
- 求逆序对数
- HDU-3734 逆序对数
- 求逆序对数
- 逆序对数 题目
- 求数组逆序对数
- 10.求逆序对数
- 求逆序对数
- poj 求逆序对数
- 1:求逆序对数
- 归并求逆序对数
- 数组中的逆序对数
- openjudge 求逆序对数
- 归并求逆序对数
- [hdu-] Sum Problem
- MapReduce工作原理图文详解
- android 图片处理
- 成功人的共同特点
- poj 3185 The Water Bowls(高斯消元)
- 【InversionCount 逆序对数 + MergeSort】
- mapreduce程序实现排序
- dojo小例子(12)form转换成带内部对象的json数据
- j2ee规范13种
- jquery mobile如何实现滑动屏幕跳转页面
- 使用ImageSwitcher实现换图片
- leetcode之Best Time to Buy and Sell StockII
- uva10361 - Automatic Poetry
- 最大流和二分匹配