#include<bits/stdc++.h>
using namespace std;
#define pii pair<int,int>
#define tiii tuple<int,int,int>
int INF = 1e9;
int main(){
int n, m;
cin >> n >> m;
vector<vector<int>> adj(n);
for(int i = 0; i < n; i++){
int a,b;
cin >> a >> b;
a--;b--;
adj[a].push_back(b);
adj[b].push_back(a);
}
int k;
cin >> k;
vector<vector<int>> watchmen(k);
vector<int> len(k);
int ma = 0;
int leastcm = 1;
for(int i = 0; i < k; i++){
int l;
cin >> l;
len[i] = l;
watchmen[i].resize(l);
ma = max(ma,l);
leastcm = lcm(leastcm, l);
for(int j = 0; j < l; j++){
cin >> watchmen[i][j];
watchmen[i][j]--;
}
}
queue<pii> q;
vector<vector<int>> dist(leastcm, vector<int>(n, INF));
q.push({0,0});
while(q.size()){
int d,v;
tie(d,v) = q.front(); q.pop();
bool valid = true;
for(int i = 0; i < k; i++){
if(watchmen[i][d%len[i]] == v) {
valid = false;
break;
}
}
if(!valid || dist[d%leastcm][v] <= d) continue;
dist[d%leastcm][v] = d;
q.push({d+1,v});
for(auto u : adj[v]){
bool valid2 = true;
for(int i = 0; i < k; i++){
if(watchmen[i][d%len[i]] == u && watchmen[i][(d+1)%len[i]] == v) {
valid2 = false;
break;
}
}
if(!valid2){
continue;
}
q.push({d+1, u});
}
}
int mi = INF;
for(int i = 0; i < leastcm; i++){
mi = min(mi, dist[i][n-1]);
}
if(mi == 1e9){
cout << "impossible" << endl;
return 0;
}
cout << mi << 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... |