归并排序求逆序对

原创 2015年11月21日 07:49:11

归并排序求逆序对


我们知道归并排序是递归的对左右两边区间排序,然后将已经有序的左边区间和右边区间合并。合并的时候,假设左边区间范围是 l <= i < mid 右边的范围是 mid <= j < r ,

如果a[i] <= a[j],那么没有逆序对产生, 如果 a[i] > a[j] ,那么 所有 a[i] .. a[i+i] ... a[mid-1]这些数都是大于a[j]的,因为左边区间已经有序。所以只要每次遇到 a[i] > a[j], ans += mid - i,就能求出所有的逆序对。


题目:http://poj.org/problem?id=1804


源代码

#include <iostream>
#include <cstdio>
using namespace std;
const int maxn = 1111;
int a[maxn],tmp[maxn];
int ans;
void Merge(int l,int m, int r){
	int i=l;
	int j = m;
	int k = l;
	while(i < m && j < r){
		if(a[i] > a[j]){
			tmp[k++] = a[j++];
			ans += m - i ;
		}
		else
			tmp[k++] = a[i++];
	}
	while(i < m) tmp[k++] = a[i++];
	while(j < r) tmp[k++] = a[j++];
	for(int i=l;i<r;i++)
		a[i] = tmp[i];
}
void Merge_Sort(int l,int r){
	if(r - l > 1){
		int m = (l + r) >>1;
		Merge_Sort(l,m);
		Merge_Sort(m,r);
		Merge(l,m,r);
	}
}
int main(){
	int t;
	scanf("%d",&t);
	int cnt = 1;
	while(t--){
		int n;
		scanf("%d",&n);
		for(int i=0;i<n;i++)
			scanf("%d",&a[i]);
		ans = 0;
		Merge_Sort(0,n);
		// for(int i=0;i<n;i++)
		// printf("%d\n",a[i]);
		printf("Scenario #%d:\n%d\n\n",cnt++,ans);
	}
	return 0;
}



版权声明:本文为博主原创文章,未经博主允许不得转载。个人博客http://www.winjourn.cn

归并排序的实现及利用其求逆序对数

归并排序,顾名思义:递归+合并   合并:是将两个数列合并,如1 6 4 和 2 5 3合并,为了方便,我们将其命名为数列1和数列2   合并数列1和数列2,   从两者的最左边的位置开始比较,   ...

归并排序算法求逆序对数

归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列(即先使...

poj 2299 树状数组+离散化 or 归并排序 求逆序对

题意: 给一个n 求逆序对。 解析: 树状数组+离散化是一种方法。 归并排序是一种方法。 线段树+离散化应该也ok。 树状数组: 离散化完了以后:(以下转载) 假设...

【NOI导刊】【归并排序求逆序对】最接近神的人

题目描述破解了符文之语,小FF开启了通往地下的道路。当他走到最底层时,发现正前方有一扇巨石门,门上雕刻着一幅古代人进行某种活动的图案。而石门上方用古代文写着“神的殿堂”。小FF猜想里面应该就有王室的遗...

【bzoj 十连测】[noip2016十连测第三场]Problem A: 平均数(二分答案+归并排序求逆序对)

抚琴之人泪满衫,扬花萧萧落

Ultra-QuickSort (poj 2299 归并排序 || 树状数组 求逆序对)

题意:求n个数的逆序对。

归并排序求逆序对

排序都用Qsort了,别的排序算法不怎么用,但有些排序的思想很重要。碰到一道求逆序对的题,要用到归并排序,学习了一下归并排序。归并排序是用分治思想,分治模式在每一层递归上有三个步骤:         ...
  • swm8023
  • swm8023
  • 2011年06月11日 07:35
  • 5936

哈理工OJ 2224 逆序对问题(利用归并排序求逆序数对数)

题目链接:http://acm.hrbust.edu.cn/index.php?m=ProblemSet&a=showProblem&problem_id=2224逆序对问题 Time Limit:...

poj2299(求逆序对,归并排序)

归并排序求逆序对了,只要是逆序对的,肯定就会有交换的操作了,然后归并排序的时候,此时新数组放右边的数字时,计算逆序对个数(就是还未放入的个数),然后就可以得到答案了。   #include "std...

利用归并排序求逆序对

在逆序对的问题中,如果采用暴力求解的方法,一般也是有效的,但是O(n2)时间复杂度实在是难以接受的。但是对于逆序对问题,却有一个看似不想关的算法来解决–归并排序。时间复杂度和空间复杂度完全与归并排序一...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:归并排序求逆序对
举报原因:
原因补充:

(最多只允许输入30个字)