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 <bits/stdc++.h>
using namespace std;
const int maxn = 1e5 + 10;
const int inf = 1e9;
int pai[maxn], peso[maxn], h[maxn];
int n, m, q;
void init( int n ){ for( int i = 0; i <= n; i++ ) pai[i] = i, peso[i] = inf; }
int find( int a ){ return ( a == pai[a] ) ? a : find( pai[a] ); }
void join( int a, int b, int id ){
a = find(a), b = find(b);
if( a == b ) return;
if( h[a] < h[b] + 1 ) swap( a, b );
pai[b] = a; peso[b] = id;
h[a] = max( h[a], h[b] + 1 );
}
void solve( int id ){
int k = m - id + 1;
for( int i = 2*k; i <= n; i += k ) join( k, i, id );
}
int query( int a, int b ){
int resp = 0;
while( a != b ){
if( peso[a] < peso[b] ) resp = max( resp, peso[a] ), a = pai[a];
else resp = max( resp, peso[b] ), b = pai[b];
}
return resp;
}
int main(){
cin >> n >> m >> q;
init(n);
for( int i = 1; i <= m; i++ ) solve(i);
while( q-- ){
int a, b; cin >> a >> b;
cout << query( a, b ) << endl;
}
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |