이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
#include "shoes.h"
long long count_swaps(vector<int> s)
{
size_t const n = s.size();
vector<bool> processed(n, 0);
vector<priority_queue<unsigned, vector<unsigned>, greater<unsigned>>> q(n);
for (unsigned i = 0; i < n; i++)
q[2 * (abs(s[i]) - 1) + (s[i] < 0)].push(i);
long long swaps_needed = 0;
for (unsigned i = 0; i < n; i++)
{
if (!processed[i])
{
processed[i] = 1;
while (processed[q[2 * (abs(s[i]) - 1) + (s[i] > 0)].top()])
q[2 * (abs(s[i]) - 1) + (s[i] > 0)].pop();
unsigned j = q[2 * (abs(s[i]) - 1) + (s[i] > 0)].top();
q[2 * (abs(s[i]) - 1) + (s[i] > 0)].pop();
processed[j] = 1;
swaps_needed += j - i - (s[i] < 0);
}
}
return swaps_needed;
}
# | 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... |