# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
787714 | vnm06 | Sorting (IOI15_sorting) | C++14 | 1 ms | 340 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 "sorting.h"
#include<bits/stdc++.h>
using namespace std;
int n;
int a[200005];
int b[200005];
int prebroj()
{
int ans=n;
for(int i=0; i<n; i++)
{
if(!b[i]) continue;
ans--;
int t=b[i]-1;
b[i]=0;
while(b[t]!=0)
{
int t2=b[t];
b[t]=0;
t=t2-1;
}
}
return ans;
}
int sp[2][200005], brsp=0;
int pos[200005];
int findSwapPairs(int N, int S[], int M, int X[], int Y[], int P[], int Q[])
{
n=N;
for(int i=0; i<n; i++) a[i]=S[i];
int le=-1, ri=M;
for(int i=0; i<n; i++) b[i]=a[i];
ri=prebroj();
for(int i=0; i<n; i++) pos[b[i]]=i;
for(int i=0; i<n; i++)
{
if(b[i]==i+1) continue;
sp[0][brsp]=b[i];
sp[1][brsp]=i+1;
brsp++;
int tp=pos[i+1];
pos[b[i]]=pos[i+1];
pos[i+1]=i;
swap(b[i], b[tp]);
}
for(int i=0; i<n; i++) pos[a[i]]=i;
for(int i=0; i<brsp; i++)
{
P[i]=pos[sp[0][i]];
Q[i]=pos[sp[1][i]];
swap(pos[sp[0][i]], pos[sp[1][i]]);
swap(a[pos[sp[0][i]]], a[pos[sp[1][i]]]);
}
for(int i=brsp; i<ri; i++) P[i]=Q[i]=0;
return ri;
}
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... |