就是用归并排序求数组中得逆序对。假设数组为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. (转)前端:将网站打造成单页面应用SPA

    前端:将网站打造成单页面应用SPA(一) Coffce 680 6月19日 发布 推荐 6 推荐 收藏 85 收藏,3.1k 浏览 前言 不知你有没有发现,像Github.百度.微博等这些大站,已经不 ...

  2. WHERE字句

    structured query language(非过程性的结构查询语言) 主要内容: 数据库怎么限制里面的数据: 数据库怎么排列里面的数据. WHERE子句: --WHERE字句起到的是对数据库查 ...

  3. js的实例方法和静态方法分析

    var Person=function(){}; Person.say=function(){ console.log('I am a Person,I can say.') }; Person.pr ...

  4. JZOJ.5273【NOIP2017模拟8.14】亲戚

    Description

  5. ZOJ 2676 Network Wars[01分数规划]

    ZOJ Problem Set - 2676 Network Wars Time Limit: 5 Seconds      Memory Limit: 32768 KB      Special J ...

  6. Golang Frameworks

    Web frameworks help developers build applications as easily and quickly as possible. Go is still rel ...

  7. visual studio 2017 编译v140 TRACKER : error TRK0005: Failed to locate: "CL.exe". 系统找不到指定的文件

    原因可能是vs2017中配置v140 的编译命令路径有问题 解决方案: 用vs2017的在线安装程序,选择修改 进去后选择单个组建,在编译器.生成工具和运行时里面把vc++2015.3…… 打钩的取消 ...

  8. mysql insert中用case

    insert into urls(company,counterType,mdUrl,tradeUrl) values('test', CASE 'test'WHEN 'CTP' THEN 1WHEN ...

  9. ubuntu-16.04.2-server-amd64.iso

    w

  10. 2015-04-14——css3 @media

    //判断横竖屏 @media screen and (min-aspect-ratio: 13/13) { body {background-color:red;}}  //屏幕宽高比,必须是除数形式 ...