# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
824236 | LucaIlie | Minerals (JOI19_minerals) | C++17 | 3 ms | 592 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 "minerals.h"
#include <bits/stdc++.h>
using namespace std;
const int MAX_N = 43000;
const int B = 100;
const int UNDEF = -1;
int perm[2 * MAX_N + 1], pairr[2 * MAX_N + 1];
set<int> notPaired, s;
vector<int> pairedQueue;
void Solve( int n ) {
for ( int i = 0; i < 2 * n; i++ ) {
perm[i] = i + 1;
pairr[i] = UNDEF;
notPaired.insert( i );
}
random_shuffle( perm, perm + 2 * n );
int it = 0;
while ( !notPaired.empty() && it++ < 10 ) {
pairedQueue.clear();
for ( int i: notPaired ) {
int x = Query( perm[i] );
if ( x > B ) {
Query( perm[i] );
continue;
}
if ( x == s.size() ) {
int p = UNDEF;
for ( int j: s ) {
int y = Query( perm[j] );
if ( x == y ) {
p = j;
break;
} else
Query( perm[j] );
}
pairr[i] = p;
pairr[p] = i;
pairedQueue.push_back( i );
pairedQueue.push_back( p );
s.erase( p );
Query( perm[i] );
} else
s.insert( i );
}
for ( int i: pairedQueue )
notPaired.erase( i );
}
for ( int i = 0; i < 2 * n; i++ ) {
if ( pairr[i] < i )
Answer( perm[pairr[i]], perm[i] );
}
}
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... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |