blob: efc7a82b88c718a3e6c160865c96e16a7fc07dfd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
#include <iostream>
#include <vector>
using std::vector;
long long get_number_of_inversions(vector<int> &a, vector<int> &b, size_t left, size_t right) {
long long number_of_inversions = 0;
if (right <= left + 1) return number_of_inversions;
size_t ave = left + (right - left) / 2;
number_of_inversions += get_number_of_inversions(a, b, left, ave);
number_of_inversions += get_number_of_inversions(a, b, ave, right);
//write your code here
return number_of_inversions;
}
int main() {
int n;
std::cin >> n;
vector<int> a(n);
for (size_t i = 0; i < a.size(); i++) {
std::cin >> a[i];
}
vector<int> b(a.size());
std::cout << get_number_of_inversions(a, b, 0, a.size()) << '\n';
}
|