标签:poj
| Time Limit: 7000MS | Memory Limit: 65536K | |
| Total Submissions: 39397 | Accepted: 14204 |
Description
Input
Output
Sample Input
5 9 1 0 5 4 3 1 2 3 0
Sample Output
6 0
并归排序。
另外,此题有一坑就是结果会超int32;具体可以参考:点击打开链接
我写的代码如下:
#include<cstdio>
#include<stdlib.h>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
const int M = 500000 + 5;
int n, A[M], T[M], i;
long long merge_sort(int l, int r, int *A)
{
if (r - l < 1) return 0;
int mid = (l + r) / 2;
long long ans = merge_sort(l, mid, A) + merge_sort(mid + 1, r, A);
i = l;
int p = l, q = mid + 1;
while (p <= mid && q <= r)
{
if(A[p] <= A[q])
T[i++] = A[p++];
else
{
ans += (mid + 1 - p);
T[i++] = A[q++];
}
}
while (p <= mid) T[i++] = A[p++];
while (q <= r) T[i++] = A[q++];
for (int j = l; j <= r; j++)
A[j] = T[j];
return ans;
}
int main()
{
int n;
while(scanf("%d", &n) && n)
{
for(int j=0; j<n; j++)
scanf("%d", &A[j]);
printf("%lld\n", merge_sort(0, n - 1, A));
}
return 0;
}
POJ 2299:Ultra-QuickSort,布布扣,bubuko.com
标签:poj
原文地址:http://blog.csdn.net/u013487051/article/details/37519411