hdu4911 逆序对
时间: 2024-02-10 07:06:21 浏览: 162
逆序对问题
5星 · 资源好评率100%
hdu4911 逆序对 是一个经典的归并排序问题,题目描述如下:
给定一个长度为 n 的数组,求其中逆序对的数量,逆序对指的是所有满足 i < j 且 a[i] > a[j] 的 (i, j) 对数。
具体做法是使用归并排序,在排序的过程中统计逆序对的数量。将数组不断分成两半,分别对左半部分和右半部分进行归并排序,然后将两个有序的部分合并成一个有序的数组,并在合并的过程中统计逆序对的数量。
以下是 hdu4911 逆序对 的 C++ 代码实现:
```cpp
#include <iostream>
using namespace std;
typedef long long ll;
const int maxn = 500010;
int a[maxn], b[maxn];
ll merge_sort(int l, int r) {
if (l == r) return 0;
int mid = (l + r) / 2;
ll res = merge_sort(l, mid) + merge_sort(mid + 1, r);
int i = l, j = mid + 1, k = 0;
while (i <= mid && j <= r) {
if (a[i] <= a[j]) {
b[k++] = a[i++];
} else {
b[k++] = a[j++];
res += mid - i + 1;
}
}
while (i <= mid) b[k++] = a[i++];
while (j <= r) b[k++] = a[j++];
for (int i = 0; i < k; i++) {
a[l + i] = b[i];
}
return res;
}
int main() {
int n;
while (cin >> n && n != 0) {
for (int i = 0; i < n; i++) {
cin >> a[i];
}
ll ans = merge_sort(0, n - 1);
cout << ans << endl;
}
return 0;
}
```
时间复杂度为 O(nlogn),其中 n 表示数组的长度。因为归并排序的时间复杂度为 O(nlogn),在合并的过程中统计逆序对的数量的时间复杂度为 O(n),因此总的时间复杂度为 O(nlogn)。
阅读全文