이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "shoes.h"
#include <bits/stdc++.h>
using namespace std;
#define itr(a) a.begin(), a.end()
typedef vector<int> vi;
typedef unordered_map<int, int> mii;
void move(mii &chain, mii &rev, int a, int b)
{
chain[rev[a]] = chain[a];
rev[chain[a]] = rev[a];
chain[a] = chain[b];
rev[chain[b]] = a;
chain[b] = a;
rev[a] = b;
}
int cost(mii chain, int a, int b, int c = 0)
{
if (a == b)
return c;
c++;
return cost(chain, chain[a], b, c);
}
long long count_swaps(vi s)
{
int n = s.size(), l = 0;
long long c = 0;
mii chain, rev;
unordered_map<int, priority_queue<int>> ref;
chain[-1] = 0;
rev[0] = -1;
for (int i = 0; i < n; i++)
{
if (i != n - 1)
{
chain[i] = i + 1;
rev[i + 1] = i;
}
ref[s[i]].push(-i);
}
for (int i = 0; i < n / 2; i++)
{
int ln = s[l], li = l, cst = 0;
while (s[li] != -ln)
{
li = chain[li];
cst++;
}
if (ln < 0)
{
c += cst - 1;
move(chain, rev, li, l);
l = chain[li];
}
else
{
c += cst;
move(chain, rev, li, rev[l]);
l = chain[l];
}
}
return c;
}
# | 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... |