This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "shoes.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define endl "\n"
#define all(x) x.begin(),x.end()
struct Fenwick {
int n;
vector<int> arr;
Fenwick(int n) : n(n), arr(n+1) {}
int query(int p) {
int acc = 0;
for (; p > 0; p -= p & -p)
acc += arr[p];
return acc;
}
int query(int l, int r) {
return query(r) - query(l);
}
void update(int i, int x) {
for (i++; i <= n; i += i & -i)
arr[i] += x;
}
};
long long count_swaps(std::vector<int> s) {
int n = s.size();
map<int, set<int>> m;
vector<bool> done(n);
for (int i = 0; i < n; i++)
m[s[i]].insert(i);
Fenwick fen(n);
for (int i = 0; i < n; i++)
fen.update(i, 1);
ll res = 0;
for (int i = 0; i < n; i++) {
if (done[i]) continue;
res += s[i] > 0;
auto it = m[-s[i]].lower_bound(i);
int j = *it;
m[-s[i]].erase(it);
done[i] = true;
fen.update(i, -1);
done[j] = true;
fen.update(j, -1);
res += fen.query(i, j);
}
return res;
}
# | 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... |