就是用归并排序求数组中得逆序对。假设数组为a:[2 4 5],和b:[1 3],那么在这一次归并的时候逆序对这样求,belement表示当前result数组中b数组对应的元素个数,total表示逆序对的个数:

a:[2 4 5]  b:[1 3]   result{}

a:[2 4 5]  b[3]       result{1}              belement = 1;

a:[4 5]  b[3]          result{1 2}           belement = 1;        total = total + belement = 1;

a:[4 5]  b[]          result{1 2 3}        belement = 2;        total = 1;

a:[5]  b[]               result{1 2 3 4}     belement = 2;        total = total + belement = 3

a:[]  b[]                 result{1 2 3 4 5}  belement = 2;        total = total + belement = 5

所以数组2 4 5 1 3的逆序数总共有5个。

JAVA版本代码如下:注意total要设置成long型防止溢出。

 import java.util.Scanner;
public class Main { public static void main(String[] args) {
// TODO Auto-generated method stub Scanner in = new Scanner(System.in);
int n = in.nextInt();
int[] arr = new int[n];
for(int i = 0;i < n;i++)
arr[i] = in.nextInt();
MergeSort(arr,0,arr.length-1);
/*
for(int i = 0;i < arr.length;i++)
System.out.print(arr[i]);
*/
System.out.print(total);
}
private static void MergeSort(int[] arr,int begin,int end){
if(begin >= end)
return;
int mid = (begin+end)/2;
MergeSort(arr, begin, mid);
MergeSort(arr, mid+1, end);
merge(arr, begin, end);
}
public static long total = 0;
private static void merge(int[] arr,int begin,int end){
int belement = 0;
int mid = (begin+end)/2;
int p1 = begin;
int p2 = mid+1;
int count = 0;
int[] sorted = new int[end-begin+1]; while(p1 <= mid && p2 <= end){
if(arr[p1] > arr[p2]){
sorted[count] = arr[p2];
p2++;
count++;
belement++;
//System.out.println(belement);
}else{
total += belement;
sorted[count] = arr[p1];
p1++;
count++;
}
} while(p1 <= mid){
sorted[count] = arr[p1];
count++;
p1 ++;
total += belement;
} while(p2 <= end){
sorted[count] = arr[p2];
count ++;
p2++;
} for(int i = begin;i <= end;i++)
arr[i] = sorted[i-begin];
} }

【hihocoder】三十九周:二分.归并排序之逆序对的更多相关文章

  1. hiho一下 第三十九周 归并排序求逆序数

    题目链接:http://hihocoder.com/contest/hiho39/problem/1 ,归并排序求逆序数. 其实这道题也是可以用树状数组来做的,不过数据都比较大,所以要离散化预处理一下 ...

  2. 剑指offer三十五之数组中的逆序对

    一.题目 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%1000 ...

  3. hihocoder第三十六周 二分查找

    题目链接:http://hihocoder.com/contest/hiho36/problem/1 , 一个比较简单的二分. 算法: 由于数据量比较大,O(nlogn)无法通过,所以不能先排序再查找 ...

  4. hiho一下 第三十八周 二分答案

    题目链接:http://hihocoder.com/contest/hiho38/problem/1 ,挺难想的解题思路,好题. 按照提示的算法来: 我们需要找什么? 在这个题目中我们需要找的是路径最 ...

  5. 【hihocoder】二分·归并排序之逆序对

    描述 在上一回.上上回以及上上上回里我们知道Nettle在玩<艦これ>.经过了一番苦战之后,Nettle又获得了的很多很多的船.这一天Nettle在检查自己的舰队列表:我们可以看到,船默认 ...

  6. hihoCoder#1141 二分·归并排序之逆序对

    原题地址 又是一道WA成狗的题,最后发现原来是结果溢出了.. 代码: #include <iostream> #include <cstring> using namespac ...

  7. 【hiho39】二分·归并排序之逆序对

    近期申请了微软的暑假实习,4号就要在线笔试了,在线測试系统用的是http://hihocoder.com/,今天试手做了一道题. [题目] 原题链接:http://hihocoder.com/cont ...

  8. hihoCoder_二分&#183;归并排序之逆序对

    一.题目 题目1 : 二分·归并排序之逆序对 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 在上一回.上上回以及上上上回里我们知道Nettle在玩<艦これ&g ...

  9. Java进阶(三十九)Java集合类的排序,查找,替换操作

    Java进阶(三十九)Java集合类的排序,查找,替换操作 前言 在Java方向校招过程中,经常会遇到将输入转换为数组的情况,而我们通常使用ArrayList来表示动态数组.获取到ArrayList对 ...

随机推荐

  1. cout顺序,i++和++i

    先看下以下代码 #include<iostream> using namespace std; ; int f1() { x = ; return x; } int f2() { x = ...

  2. python中的self

    1.首先明确的是self只有在类的方法中才会有,独立的函数或方法是不必带有self的.self在定义类的方法时是必须有的,虽然在调用时不必传入相应的参数. self名称不是必须的,在python中se ...

  3. zoj3662(dp)

    dp还是比较好想的,但是时间还是比较坑的. 要预处理还加些优化才行 . #include <stdio.h> #include <stdlib.h> #include < ...

  4. JZOJ.3777【NOI2015模拟8.17】最短路(shortest)

    Description        小Y最近学得了最短路算法,一直想找个机会好好练习一下.话虽这么说,OJ上最短路的题目都被他刷光了.正巧他的好朋友小A正在研究一类奇怪的图,他也想凑上去求下它的最短 ...

  5. Java String.replaceAll() 与后向引用(backreference)

    问题 昨天看到一篇博文,文中谈到一道 Java 面试题: 给定一字符串,若该字符串中间包含 "*",则删除该 "*":若该字符串首字符或尾字符为 "* ...

  6. Visual Studio 2010 如何改用 Beyond Compare 作为 TFS 的比较工具

    Beyond Compare 是一套非常实用的文件及文件夹比较软件,不仅可以快速比较出两个文件夹的不同之处,还可以详细的比较文件之间的内容差异.最近改用 TFS 进行版本控管之后,说实在的还是习惯使用 ...

  7. 170210、JAVA中List、Map、Set的区别与选用

    先了解下类层次关系: Collection ├List│├LinkedList│├ArrayList│└Vector│ └Stack└SetMap├Hashtable├HashMap └WeakHas ...

  8. Linux ssh其他服务器

  9. sqli_labs第一关

    安装 从https://github.com/Audi-1/sqli-labs下载源代码 搭建环境用的是phpstudy 编辑sqli\sql-connections\db-creds.inc文件 修 ...

  10. soft deletion Google SRE 保障数据完整性的手段

    w http://www.infoq.com/cn/articles/GoogleSRE-BookChapter26 Google SRE 保障数据完整性的手段 就像我们假设Google 的底层系统经 ...