📄 2299.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 + -