归并排序求逆序对

原创 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

相关文章推荐

利用归并排序求逆序对

在逆序对的问题中,如果采用暴力求解的方法,一般也是有效的,但是O(n2)时间复杂度实在是难以接受的。但是对于逆序对问题,却有一个看似不想关的算法来解决–归并排序。时间复杂度和空间复杂度完全与归并排序一...

归并排序求逆序对

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

归并排序求逆序对

转载自归并排序求逆序对详解 希望此大犇不要生气。 联赛之前发现自己好多都忘记了,于是开始方,于是开始到处乱搞,想起以前的离散化+归并排序求逆序对NOIP水题火柴排队现在都不会了,于是在网上狂找归并...

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

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

poj 2299 归并排序求逆序对 解题报告

Ultra-QuickSort

poj1804 Brainman 归并排序求逆序对

Problem Here’s what Charlie thinks of. Imagine you get a sequence of N numbers. The goal is to mov...

归并排序求数组逆序对

第四章 逆序对 4.1 题目 在数组中的两个数字如果前面的一个数字大于后面的数字,则这两个数字组成了一个逆序对;输入一个数组求该数组中的逆序对个数 比如:数组{ 1, 5, 7, 3, 2},则逆序对...

归并排序求逆序对数

http://poj.org/problem?id=2299 给出n个数,每次只能交换两个相邻的数,问使得n个数有序最少需要交换多少次。 归并排序的模板,重在理解,小白书p144. #incl...

利用归并排序思想求数组中的逆序对

http://blog.csdn.net/seuliujiaguo/article/details/39555481 这是快排其他的应用 http://blog.csdn.net/seuliuji...

poj 2299 Ultra-QuickSort 求逆序对,树状数组和归并排序

//树状数组 #include #include using namespace std; int a[500050],c[500050],n; struct node { int num,i...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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