# | TimeUTC-0 | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
724230 | badont | Arranging Shoes (IOI19_shoes) | C++17 | 47 ms | 13992 KiB |
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 <cmath>
#include <cstdlib>
#include <cassert>
long long count_swaps(std::vector<int> s) {
using ll = long long;
using namespace std;
ll n = (int)s.size(); n /= 2;
vector<vector<ll>> pos(n, vector<ll>()), neg(n, vector<ll>());
for (int i = 0; i < 2 * n; i++) {
ll x = abs(s[i]);
if (s[i] < 0) {
neg[x - 1].push_back(i);
} else {
pos[x - 1].push_back(i);
}
}
ll op_1 = 0, op_2 = 0;
for (int i = 0; i < n; i++) {
assert(neg[i].size() == pos[i].size());
for (int j = 0; j < (int)neg[i].size(); j++) {
int x = neg[i][j], y = pos[i][j];
op_1 += abs(x - y) - 1;
if (x > y) op_2++;
}
}
# | 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... |