Tyvj_P3044 极端快排

P3044 极端快排
时间: 1000ms / 空间: 65536KiB / Java类名: Main

描述

精灵王如此机智,得益于年轻时候的好奇心和热爱思考的习惯。 
话说当年精灵王只有16岁,就思考这样的问题: 
给定n个不同的整数,我们可以通过不断交换相邻的两个元素将它们升序排列呢。精灵王称之为“极端快排”。比如对于序列 
9 1 0 5 4 
极端快排后是 
0 1 4 5 9 
精灵王思考的问题是,对于给定的序列至少需要多少次两两相邻交换操作,才能完成排序。 

输入格式

输入包含多组数据。对于每组数据: 
第1行:整数n表示序列长度。(n 
第2…n+1行:每一行包含一个整数a[i],表示数列中的一个元素。(0 ≤ a[i] ≤ 999,999,999) 
输入以n = 0结束,这组数据不用处理。 

输出格式

第1行:最少的两两相邻交换次数。

测试样例1

输入











0

输出


0
#include<stdio.h>
void merge_sort(__int64 *,__int64 ,__int64 ,__int64 *);
__int64 count;
__int64 a[2000000],t[2000000];
int main()
{
	__int64 n;
	while(scanf("%I64d",&n)==1&&n) 
	{
			count=0;  //  每次循环都要初始化一次 
			for(__int64 i=0;i<n;i++)
				scanf("%I64d",&a[i]);
			merge_sort(a,0,n,t);
			printf("%I64d\n",count);
	}
	return 0;
}

void merge_sort(__int64 *a,__int64 x,__int64 y,__int64 *t)
{
	if(y-x>1)
	{
		__int64 m=x+(y-x)/2;
		merge_sort(a,x,m,t);
		merge_sort(a,m,y,t);
		__int64 p=x,q=m,i=x;
		while(p<m||q<y)
		{
			if(q>=y||(p<m&&a[p]<=a[q])) t[i++]=a[p++];
			else {t[i++]=a[q++];count+=m-p;}     // 记录逆序对数 
		}
		for(i=x;i<y;i++) a[i]=t[i];
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值