#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
#define int long long
const int MOD = pow(10,9)+7;
const int MOD2 = 998244353;
const int INF = LLONG_MAX/2;
int primes[1000000];
void seive(){
fill(primes, primes + 1000000, 1);
primes[0] = primes[1] = 0;
for(int i = 2 ; i*i < 1000000 ; i++){
if(primes[i]){
for(int j = i*i ; j < 1000000 ; j += i){
primes[j] = 0;
}
}
}
for(int i = 1 ; i < 1000000 ; i++){
primes[i] += primes[i-1];
}
}
int factorial(int n){
if(n==0){
return 1;
}
return (n*(factorial(n-1)))%MOD;
}
bool isPrime(int n){
if(n <= 1) return false;
for(int i = 2 ; i*i <= n ; i++){
if(n % i == 0) return false;
}
return true;
}
int power(int a, int b){
if(b == 0) return 1;
a %= MOD;
int value = power(a, b / 2);
if(b % 2 == 0){
return (value * value) % MOD;
} else {
return ((value * value) % MOD * (a % MOD)) % MOD;
}
}
int gcd(int a, int b){
if(a == 0) return b;
return gcd(b % a, a);
}
void solve() {
int n1,m1;
cin>>n1>>m1;
vector<int>A[n1+1];
int value[n1+1];
for(int i = 0 ; i<m1 ; i++){
int a,b;
cin>>a>>b;
A[a].push_back(b);
A[b].push_back(a);
}
for(int i = 1 ; i<=n1 ; i++){
cin>>value[i];
}
int d;
cin>>d;
queue<int>q;
int visited[n1+1] = {0};
int level[n1+1] = {0};
int five[n1+1] = {0};
visited[d] = 1;
if(value[d]==5){
five[d] = 1;
}
q.push(d);
while(!q.empty()){
int node = q.front();
q.pop();
for(auto node1 : A[node]){
if(!visited[node1]){
q.push(node1);
visited[node1] = 1;
level[node1] = level[node]+1;
if(value[node1]==5){
five[node1] = 1+five[node];
}
else{
five[node1] = five[node];
}
}
else{
if((level[node]+1)==(level[node1])){
if(value[node1]==5){
five[node1] = max((1+five[node]),five[node1]);
}
else{
five[node1] = max(five[node],five[node1]);
}
}
}
}
}
for(int i = 1; i <= n1; i++) {
cout << "Node " << i << ": Shortest Path Length = " << level[i]
<< ", Max 5s = " << five[i] << endl;
}
}
signed main(){
ios::sync_with_stdio(false); cin.tie(NULL);
//int t;
//cin >> t;
//while(t--){
solve();
//}
return 0;
}
I2luY2x1ZGU8Yml0cy9zdGRjKysuaD4KdXNpbmcgbmFtZXNwYWNlIHN0ZDsKI2RlZmluZSBlbmRsICdcbicKI2RlZmluZSBpbnQgbG9uZyBsb25nCmNvbnN0IGludCBNT0QgPSBwb3coMTAsOSkrNzsKY29uc3QgaW50IE1PRDIgPSA5OTgyNDQzNTM7CmNvbnN0IGludCBJTkYgPSBMTE9OR19NQVgvMjsKIAppbnQgcHJpbWVzWzEwMDAwMDBdOwogCnZvaWQgc2VpdmUoKXsKICAgIGZpbGwocHJpbWVzLCBwcmltZXMgKyAxMDAwMDAwLCAxKTsKICAgIHByaW1lc1swXSA9IHByaW1lc1sxXSA9IDA7CiAgICBmb3IoaW50IGkgPSAyIDsgaSppIDwgMTAwMDAwMCA7IGkrKyl7CiAgICAgICAgaWYocHJpbWVzW2ldKXsKICAgICAgICAgICAgZm9yKGludCBqID0gaSppIDsgaiA8IDEwMDAwMDAgOyBqICs9IGkpewogICAgICAgICAgICAgICAgcHJpbWVzW2pdID0gMDsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KICAgIGZvcihpbnQgaSA9IDEgOyBpIDwgMTAwMDAwMCA7IGkrKyl7CiAgICAgICAgcHJpbWVzW2ldICs9IHByaW1lc1tpLTFdOwogICAgfQp9CmludCBmYWN0b3JpYWwoaW50IG4pewogICAgaWYobj09MCl7CiAgICAgICAgcmV0dXJuIDE7CiAgICB9CiAgICByZXR1cm4gKG4qKGZhY3RvcmlhbChuLTEpKSklTU9EOwp9CmJvb2wgaXNQcmltZShpbnQgbil7CiAgICBpZihuIDw9IDEpIHJldHVybiBmYWxzZTsKICAgIGZvcihpbnQgaSA9IDIgOyBpKmkgPD0gbiA7IGkrKyl7CiAgICAgICAgaWYobiAlIGkgPT0gMCkgcmV0dXJuIGZhbHNlOwogICAgfQogICAgcmV0dXJuIHRydWU7Cn0KIAppbnQgcG93ZXIoaW50IGEsIGludCBiKXsKICAgIGlmKGIgPT0gMCkgcmV0dXJuIDE7CiAgICBhICU9IE1PRDsKICAgIGludCB2YWx1ZSA9IHBvd2VyKGEsIGIgLyAyKTsKICAgIGlmKGIgJSAyID09IDApewogICAgICAgIHJldHVybiAodmFsdWUgKiB2YWx1ZSkgJSBNT0Q7CiAgICB9IGVsc2UgewogICAgICAgIHJldHVybiAoKHZhbHVlICogdmFsdWUpICUgTU9EICogKGEgJSBNT0QpKSAlIE1PRDsKICAgIH0KfQogCmludCBnY2QoaW50IGEsIGludCBiKXsKICAgIGlmKGEgPT0gMCkgcmV0dXJuIGI7CiAgICByZXR1cm4gZ2NkKGIgJSBhLCBhKTsKfQp2b2lkIHNvbHZlKCkgewogICAgaW50IG4xLG0xOwogICAgY2luPj5uMT4+bTE7CiAgICB2ZWN0b3I8aW50PkFbbjErMV07CiAgICBpbnQgdmFsdWVbbjErMV07CiAgICBmb3IoaW50IGkgPSAwIDsgaTxtMSA7IGkrKyl7CiAgICAgICAgaW50IGEsYjsKICAgICAgICBjaW4+PmE+PmI7CiAgICAgICAgQVthXS5wdXNoX2JhY2soYik7CiAgICAgICAgQVtiXS5wdXNoX2JhY2soYSk7CiAgICB9CiAgICBmb3IoaW50IGkgPSAxIDsgaTw9bjEgOyBpKyspewogICAgICAgIGNpbj4+dmFsdWVbaV07CiAgICB9CiAgICBpbnQgZDsKICAgIGNpbj4+ZDsKICAgIHF1ZXVlPGludD5xOwogICAgaW50IHZpc2l0ZWRbbjErMV0gPSB7MH07CiAgICBpbnQgbGV2ZWxbbjErMV0gPSB7MH07CiAgICBpbnQgZml2ZVtuMSsxXSA9IHswfTsKICAgIHZpc2l0ZWRbZF0gPSAxOwogICAgaWYodmFsdWVbZF09PTUpewogICAgICAgIGZpdmVbZF0gPSAxOwogICAgfQogICAgcS5wdXNoKGQpOwogICAgd2hpbGUoIXEuZW1wdHkoKSl7CiAgICAgICAgaW50IG5vZGUgPSBxLmZyb250KCk7CiAgICAgICAgcS5wb3AoKTsKICAgICAgICBmb3IoYXV0byBub2RlMSA6IEFbbm9kZV0pewogICAgICAgICAgICBpZighdmlzaXRlZFtub2RlMV0pewogICAgICAgICAgICAgICAgcS5wdXNoKG5vZGUxKTsKICAgICAgICAgICAgICAgIHZpc2l0ZWRbbm9kZTFdID0gMTsKICAgICAgICAgICAgICAgIGxldmVsW25vZGUxXSA9IGxldmVsW25vZGVdKzE7CiAgICAgICAgICAgICAgICBpZih2YWx1ZVtub2RlMV09PTUpewogICAgICAgICAgICAgICAgICAgIGZpdmVbbm9kZTFdID0gMStmaXZlW25vZGVdOwogICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgZWxzZXsKICAgICAgICAgICAgICAgICAgICBmaXZlW25vZGUxXSA9IGZpdmVbbm9kZV07CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KICAgICAgICAgICAgZWxzZXsKICAgICAgICAgICAgICAgIGlmKChsZXZlbFtub2RlXSsxKT09KGxldmVsW25vZGUxXSkpewogICAgICAgICAgICAgICAgICAgIGlmKHZhbHVlW25vZGUxXT09NSl7CiAgICAgICAgICAgICAgICAgICAgICAgIGZpdmVbbm9kZTFdID0gbWF4KCgxK2ZpdmVbbm9kZV0pLGZpdmVbbm9kZTFdKTsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAgICAgZWxzZXsKICAgICAgICAgICAgICAgICAgICAgICAgZml2ZVtub2RlMV0gPSBtYXgoZml2ZVtub2RlXSxmaXZlW25vZGUxXSk7CiAgICAgICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9CiAgICAgICAgfQogICAgfQogICAgZm9yKGludCBpID0gMTsgaSA8PSBuMTsgaSsrKSB7CiAgICBjb3V0IDw8ICJOb2RlICIgPDwgaSA8PCAiOiBTaG9ydGVzdCBQYXRoIExlbmd0aCA9ICIgPDwgbGV2ZWxbaV0KICAgICAgICAgPDwgIiwgTWF4IDVzID0gIiA8PCBmaXZlW2ldIDw8IGVuZGw7CiAgICB9Cn0KIApzaWduZWQgbWFpbigpewogICAgaW9zOjpzeW5jX3dpdGhfc3RkaW8oZmFsc2UpOyBjaW4udGllKE5VTEwpOwogICAgLy9pbnQgdDsKICAgIC8vY2luID4+IHQ7CiAgICAvL3doaWxlKHQtLSl7CiAgICAgICAgc29sdmUoKTsKICAgIC8vfQogICAgcmV0dXJuIDA7Cn0=
Node 1: Shortest Path Length = 0, Max 5s = 0
Node 2: Shortest Path Length = 1, Max 5s = 1
Node 3: Shortest Path Length = 1, Max 5s = 0
Node 4: Shortest Path Length = 2, Max 5s = 2
Node 5: Shortest Path Length = 2, Max 5s = 1
Node 6: Shortest Path Length = 3, Max 5s = 2