# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
395380 | rocks03 | Sorting (IOI15_sorting) | C++14 | 5 ms | 460 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.
//#pragma GCC target("avx2")
//#pragma GCC optimization("O3")
//#pragma GCC optimization("unroll-loops")
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pii pair<int, int>
#define pll pair<ll, ll>
#define ff first
#define ss second
#define pb push_back
#define SZ(x) ((int)(x).size())
#define all(x) x.begin(), x.end()
#define rep(i, a, b) for(int i = (a); i < (b); i++)
#define per(i, a, b) for(int i = (a); i >= (b); i--)
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
int findSwapPairs(int N, int S[], int M, int X[], int Y[], int P[], int Q[]){
vector<int> pos(N);
rep(i, 0, N) pos[S[i]] = i;
set<int> st;
rep(i, 0, N){
if(pos[i] != i) st.insert(i);
}
auto random_sol = [&](){
int ans = 0;
while(SZ(st)){
int i = X[ans], j = Y[ans];
auto it = st.find(S[i]);
if(it != st.end())
st.erase(it);
it = st.find(S[j]);
if(it != st.end())
st.erase(it);
swap(pos[S[i]], pos[S[j]]);
swap(S[i], S[j]);
if(S[i] != i) st.insert(i);
if(S[j] != j) st.insert(j);
if(SZ(st) == 0){
P[ans] = Q[ans++] = 0; break;
}
int x = rng() % N;
it = st.lower_bound(x);
if(it == st.end()) it--;
x = *it;
i = pos[x], j = x;
it = st.find(S[i]);
if(it != st.end())
st.erase(it);
it = st.find(S[j]);
if(it != st.end())
st.erase(it);
swap(pos[S[i]], pos[S[j]]);
swap(S[i], S[j]);
if(S[i] != i) st.insert(i);
if(S[j] != j) st.insert(j);
P[ans] = i, Q[ans++] = j;
}
return ans;
};
while(true){
int ans = random_sol();
if(ans != -1) return ans;
}
}
Compilation message (stderr)
# | 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... |