이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "shoes.h"
#include <bits/stdc++.h>
using namespace std;
int n;
int a[201010];
int t[801010];
int tAdd[801010];
void build(int v, int vl, int vr) {
if (vl == vr) {
t[v] = vl;
return;
}
int vm = (vl + vr) / 2;
build(2 * v, vl, vm);
build(2 * v + 1, vm + 1, vr);
}
void push(int v, int vl, int vr) {
if (tAdd[v] == 0)return;
if (vl == vr)t[v] += tAdd[v];
else {
tAdd[2 * v] += tAdd[v];
tAdd[2 * v + 1] += tAdd[v];
}
tAdd[v] = 0;
}
void upd(int v, int vl, int vr, int l, int r, int val) {
push(v, vl, vr);
if (l <= vl && vr <= r) {
tAdd[v] += val;
push(v, vl, vr);
return;
}
if (r < vl || vr < l)return;
int vm = (vl + vr) / 2;
upd(2 * v, vl, vm, l, r, val);
upd(2 * v + 1, vm + 1, vr, l, r, val);
}
int get(int v, int vl, int vr, int pos) {
push(v, vl, vr);
if (vl == vr)return t[v];
int vm = (vl + vr) / 2;
if (pos <= vm)return get(2 * v, vl, vm, pos);
else return get(2 * v + 1, vm + 1, vr, pos);
}
vector<int> g[201010];
int pointer[201010];
int ans = 0;
bool used[201010];
int ID[201010];
long long count_swaps(std::vector<int> s) {
n = s.size();
for (int i = 1; i <= n; i++)
a[i] = s[i - 1];
build(1, 1, n);
for (int i = 1; i <= n; i++)
g[a[i] + n + 1].push_back(i);
for (int i = 1; i <= n; i++)ID[i] = i;
for (int i = 1; i <= n; i++) {
if (used[i])continue;
if (a[i] < 0) {
int Num = -a[i];
int pos = g[Num + n + 1][pointer[Num + n + 1]];
pointer[Num + n + 1]++;
pointer[a[i] + n + 1]++;
upd(1, 1, n, i + 1, pos - 1, 1);
ans += (get(1, 1, n, pos) - get(1, 1, n, i) - 1);
used[i] = true;
used[pos] = true;
continue;
}
if (a[i] > 0) {
int Num = -a[i];
int pos = g[Num + n + 1][pointer[Num + n + 1]];
pointer[Num + n + 1]++;
pointer[a[i] + n + 1]++;
upd(1, 1, n, i + 1, pos, 1);
ans += (get(1, 1, n, pos) - get(1, 1, n, i) - 1);
used[i] = true;
used[pos] = true;
continue;
}
}
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... |