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 <iostream>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <vector>
#include <set>
#include <map>
#include <cstring>
#include <queue>
using namespace std;
const int maxn=1e5+5, Log=17, pot=(1<<Log);
vector < int > svi;
void query(int L, int D, int x, int l, int d){
if(L>=l && D<=d){
svi.push_back(x);
return;
}
if((L+D)/2>=l){
query(L, (L+D)/2, x*2, l, d);
}
if((L+D)/2+1<=d){
query((L+D)/2+1, D, x*2+1, l, d);
}
}
pair < int, int > a[maxn];
set < int > s;
map < int, int > m;
int dist[pot*2];
int d[maxn];
vector < pair < int, int > > ms[pot*2];
void precompute(){
for(int i=2; i<pot*2; i++){
ms[i].push_back({i/2, 0});
}
}
void bfs(int x){
memset(dist, -1, sizeof(dist));
memset(d, -1, sizeof(d));
queue < int > q1, q2;
q1.push(a[x].second+pot);
dist[a[x].second+pot]=0;
d[x]=0;
int tren=0;
while(!q1.empty()){
while(!q1.empty()){
x=q1.front();
q1.pop();
for(int i=0; i<(int)ms[x].size(); i++){
if(ms[x][i].second){
if(dist[ms[x][i].first]==-1){
dist[ms[x][i].first]=tren+1;
q2.push(ms[x][i].first);
}
if(d[ms[x][i].second]==-1){
d[ms[x][i].second]=tren+1;
}
}
else{
if(dist[ms[x][i].first]==-1){
dist[ms[x][i].first]=tren;
q1.push(ms[x][i].first);
}
}
}
}
q1=q2;
while(!q2.empty()){
q2.pop();
}
tren++;
}
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
precompute();
int n, q;
cin >> n >> q;
for(int i=1; i<=n; i++){
cin >> a[i].first >> a[i].second;
s.insert(a[i].first);
s.insert(a[i].second);
}
int br=0;
for(auto it=s.begin(); it!=s.end(); it++){
m[*it]=br;
br++;
}
for(int i=1; i<=n; i++){
a[i]={m[a[i].first], m[a[i].second]};
// cout << a[i].first << ' ' << a[i].second << endl;
query(0, pot-1, 1, a[i].first, a[i].second);
while(!svi.empty()){
// cout << "moji " << svi.back() << endl;
ms[svi.back()].push_back({a[i].second+pot, i});
svi.pop_back();
}
}
int x, y;
for(int i=0; i<q; i++){
cin >> x >> y;
bfs(x);
if(d[y]==-1){
cout << "impossible\n";
}
else{
cout << d[y] << '\n';
}
}
return 0;
}
# | 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... |