⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 2299.txt

📁 北大ACM题目例程 详细的解答过程 程序实现 算法分析
💻 TXT
字号:

#include <stdio.h>
#include <algorithm>
using namespace std;
int a[500000], temp[500000], n;
__int64 ans;
void merge( int l, int r )
{
	int i, j, k, c = (l+r)/2;
	if( l+1 >= r ) return ;
	merge( l, c );
	merge( c, r );
	for( i=l, j=c, k=0; i < c || j < r ;   )
	{
		if( i < c && ( j == r || a[i] < a[j] ) )
		{
			temp[k++] = a[i++];
		}
		else
		{
			temp[k++] = a[j++];
			ans += c-i;
		}
	}
	std::copy( temp, temp+k, a+l );
}
int main()
{
	int i;
	while(1)
	{
		scanf( "%d", &n );
		if( n == 0 ) break;
		for( i = 0; i < n; i++ )
			scanf( "%d", &a[i] );
		ans = 0;
		merge( 0, n );

		printf( "%I64d\n", ans );
	}
	return 0;
}


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -