2299.txt

来自「北大ACM题目例程 详细的解答过程 程序实现 算法分析」· 文本 代码 · 共 45 行

TXT
45
字号

#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 + =
减小字号Ctrl + -
显示快捷键?