이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "shoes.h"
//#include "grader.cpp"
using namespace std;
const int N = (int)1e5 + 5;
int tree[N * 4];
int a[N];
bool used[N];
map <int, int> position;
void upd(int pos, int val, int v = 0, int tl = 0, int tr = N) {
if (tl == tr) {
tree[v] += val;
return;
}
int mid = (tl + tr) >> 1;
if (pos <= mid) {
upd(pos, val, v + v + 1, tl, mid);
} else {
upd(pos, val, v + v + 2, mid + 1, tr);
}
tree[v] = tree[v + v + 1] + tree[v + v + 2];
}
int get(int l, int r, int v = 0, int tl = 0, int tr = N) {
if (l > r) {
return 0;
}
if (l <= tl && tr <= r) {
return tree[v];
}
if (l > tr || tl > r) {
return 0;
}
int mid = (tl + tr) >> 1;
return get(l, r, v + v + 1, tl, mid) + get(l, r, v + v + 2, mid + 1, tr);
}
long long count_swaps(vector<int> a) {
int n = (int)a.size() / 2;
for (int i = 0; i < n * 2; i++) {
cin >> a[i];
position[a[i]] = i;
}
long long ans = 0;
for (int i = 0; i < n * 2; i++) {
if (used[abs(a[i])]) {
continue;
}
used[abs(a[i])] = 1;
int r = position[-a[i]];
int add = (r + get(r + 1, n * 2 - 1)) - (i + get(i, n * 2 - 1) + 1);
if (a[i] > 0) {
add++;
}
ans += add;
upd(r, 1);
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |