#include "bits/stdc++.h"
using namespace std;
#define f first
#define lgn 25
#define endl '\n'
#define sc second
#define N (int)2e5+5
#define sz(x) x.size()
#define int long long int
#define ld long double
#define vi vector<int>
#define vs vector<string>
#define vc vector<char>
#define mii map<int,int>
#define pii pair<int,int>
#define vpii vector<pii>
#define test(x) while(x--)
#define pb push_back
#define eb emplace_back
#define pq priority_queue
#define mod 1000000007
#define fo(i,a,n) for(int i=a;i<n;i++)
#define rfo(i,n,a) for(int i=n;i>=a;i--)
#define mst(a,v,n) fo(i,0,n) a[i]=v
#define all(x) begin(x),end(x)
#define allr(x) rbegin(x),rend(x)
#define rev(x) reverse(begin(x),end(x))
#define db(x) cout<<#x <<" : "<< x <<endl;
#define time() cerr << "Time : " << (double)clock() / (double)CLOCKS_PER_SEC << "s\n"
const int inf = 0x3f3f3f3f;
const int INF = 0x3f3f3f3f3f3f3f3f;
int n,m,k,q,e,src;
vpii adj[N];
int vis[N],par[N],a[N],dis[N];
void bfs()
{
queue<pii> q;
fo(i,1,n+1) dis[i] = inf,vis[i] = 0; // Assigning distance and visited array
dis[src] = 0; // making starting point distance as zero
q.push({src,dis[src]}); // pushing source in queue
vis[src] = 1; // marking source as visited
while(!q.empty())
{
auto u = q.front(); // u is of datatype pair<int,int>
// u.f denotes the vertex and u.sc denotes the distance
q.pop();
for ( auto i : adj[u.f] ) // traversing all direct edges in adjacency list
{
auto v = i.f; // v is vertex directly connceted
int w = i.sc; // weight of edges u-v
if( vis[v] ) continue;
if( dis[v] > dis[u.f] + w ) // if distance from u to v is smaller than the distance then update it
{
dis[v] = dis[u.f] + w;
q.push({v,dis[v]});
vis[v] = 1;
}
}
}
}
void go()
{
cin>>n>>e;
fo(i,0,e) // loop for inputing edges
{
int u,v;
cin>>u>>v;
adj[u].pb({v,6}); // edge from u to v
adj[v].pb({u,6});// edge from v to u
}
cin>>src; // inputing source
bfs(); // calling bfs ( source is global as src so no need to pass in bfs)
fo(i,1,n+1)
{
if( i == src ) continue; // source is not required to print
if( dis[i] != inf ) cout << dis[i] <<' ';
else cout << -1 << ' ';
}
cout << endl ;
fo(i,1,n+1) adj[i].clear(); // clearing adjacency list for next test case
}
int32_t main()
{
ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t=1;
cin>>t;
test(t) go();
}
I2luY2x1ZGUgImJpdHMvc3RkYysrLmgiCgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKI2RlZmluZSAgZiBmaXJzdAojZGVmaW5lICBsZ24gMjUKI2RlZmluZSAgZW5kbCAnXG4nCiNkZWZpbmUgIHNjIHNlY29uZAojZGVmaW5lICBOIChpbnQpMmU1KzUKI2RlZmluZSAgc3ooeCkgeC5zaXplKCkKI2RlZmluZSAgaW50IGxvbmcgbG9uZyBpbnQKI2RlZmluZSAgbGQgbG9uZyBkb3VibGUKI2RlZmluZSAgdmkgdmVjdG9yPGludD4KI2RlZmluZSAgdnMgdmVjdG9yPHN0cmluZz4KI2RlZmluZSAgdmMgdmVjdG9yPGNoYXI+CiNkZWZpbmUgIG1paSBtYXA8aW50LGludD4KI2RlZmluZSAgcGlpIHBhaXI8aW50LGludD4KI2RlZmluZSAgdnBpaSB2ZWN0b3I8cGlpPgojZGVmaW5lICB0ZXN0KHgpIHdoaWxlKHgtLSkKI2RlZmluZSAgcGIgcHVzaF9iYWNrCiNkZWZpbmUgIGViIGVtcGxhY2VfYmFjawojZGVmaW5lICBwcSBwcmlvcml0eV9xdWV1ZQojZGVmaW5lICBtb2QgMTAwMDAwMDAwNwojZGVmaW5lICBmbyhpLGEsbikgZm9yKGludCBpPWE7aTxuO2krKykKI2RlZmluZSAgcmZvKGksbixhKSBmb3IoaW50IGk9bjtpPj1hO2ktLSkKI2RlZmluZSAgbXN0KGEsdixuKSBmbyhpLDAsbikgYVtpXT12CiNkZWZpbmUgIGFsbCh4KSBiZWdpbih4KSxlbmQoeCkKI2RlZmluZSAgYWxscih4KSByYmVnaW4oeCkscmVuZCh4KQojZGVmaW5lICByZXYoeCkgcmV2ZXJzZShiZWdpbih4KSxlbmQoeCkpCiNkZWZpbmUgIGRiKHgpIGNvdXQ8PCN4IDw8IiA6ICI8PCB4IDw8ZW5kbDsKI2RlZmluZSB0aW1lKCkgY2VyciA8PCAiVGltZSA6ICIgPDwgKGRvdWJsZSljbG9jaygpIC8gKGRvdWJsZSlDTE9DS1NfUEVSX1NFQyA8PCAic1xuIgoKY29uc3QgaW50IGluZiA9IDB4M2YzZjNmM2Y7CmNvbnN0IGludCBJTkYgPSAweDNmM2YzZjNmM2YzZjNmM2Y7CgppbnQgbixtLGsscSxlLHNyYzsKdnBpaSBhZGpbTl07CmludCB2aXNbTl0scGFyW05dLGFbTl0sZGlzW05dOwoKdm9pZCBiZnMoKQp7CglxdWV1ZTxwaWk+IHE7CgoJZm8oaSwxLG4rMSkgZGlzW2ldID0gaW5mLHZpc1tpXSA9IDA7IC8vIEFzc2lnbmluZyBkaXN0YW5jZSBhbmQgdmlzaXRlZCBhcnJheQoKCWRpc1tzcmNdID0gMDsgLy8gbWFraW5nIHN0YXJ0aW5nIHBvaW50IGRpc3RhbmNlIGFzIHplcm8KCglxLnB1c2goe3NyYyxkaXNbc3JjXX0pOyAvLyBwdXNoaW5nIHNvdXJjZSBpbiBxdWV1ZQoJdmlzW3NyY10gPSAxOyAvLyBtYXJraW5nIHNvdXJjZSBhcyB2aXNpdGVkCgoJd2hpbGUoIXEuZW1wdHkoKSkKCXsKCQlhdXRvIHUgPSBxLmZyb250KCk7IC8vIHUgaXMgb2YgIGRhdGF0eXBlIHBhaXI8aW50LGludD4KCQkJCQkJCS8vIHUuZiBkZW5vdGVzIHRoZSB2ZXJ0ZXggYW5kIHUuc2MgZGVub3RlcyB0aGUgZGlzdGFuY2UKCQlxLnBvcCgpOwoKCQlmb3IgKCBhdXRvIGkgOiBhZGpbdS5mXSApIC8vIHRyYXZlcnNpbmcgYWxsIGRpcmVjdCBlZGdlcyBpbiBhZGphY2VuY3kgbGlzdAoJCXsKCgkJCWF1dG8gdiA9IGkuZjsgLy8gdiBpcyB2ZXJ0ZXggZGlyZWN0bHkgY29ubmNldGVkIAoJCQlpbnQgdyA9IGkuc2M7IC8vIHdlaWdodCBvZiBlZGdlcyB1LXYKCgkJCWlmKCB2aXNbdl0gKSBjb250aW51ZTsKCgkJCWlmKCBkaXNbdl0gPiBkaXNbdS5mXSArIHcgKSAvLyBpZiBkaXN0YW5jZSBmcm9tIHUgdG8gdiBpcyBzbWFsbGVyIHRoYW4gdGhlICBkaXN0YW5jZSB0aGVuIHVwZGF0ZSBpdAoJCQl7CgkJCQlkaXNbdl0gPSBkaXNbdS5mXSArIHc7IAoJCQkJcS5wdXNoKHt2LGRpc1t2XX0pOwoJCQkJdmlzW3ZdID0gMTsKCQkJfQoJCX0KCX0KCn0KCnZvaWQgZ28oKQp7CgljaW4+Pm4+PmU7CgoJZm8oaSwwLGUpIC8vIGxvb3AgZm9yIGlucHV0aW5nIGVkZ2VzCgl7CgkJaW50IHUsdjsKCQljaW4+PnU+PnY7CgkJYWRqW3VdLnBiKHt2LDZ9KTsgLy8gZWRnZSBmcm9tIHUgdG8gdiAKCQlhZGpbdl0ucGIoe3UsNn0pOy8vIGVkZ2UgZnJvbSB2IHRvIHUKCX0KCgkJY2luPj5zcmM7IC8vIGlucHV0aW5nIHNvdXJjZQoKCQliZnMoKTsgLy8gY2FsbGluZyBiZnMgKCBzb3VyY2UgaXMgZ2xvYmFsIGFzIHNyYyBzbyBubyBuZWVkIHRvIHBhc3MgaW4gYmZzKQoKCQlmbyhpLDEsbisxKQoJCXsKCQkJaWYoIGkgPT0gc3JjICkgY29udGludWU7IC8vIHNvdXJjZSBpcyBub3QgcmVxdWlyZWQgdG8gcHJpbnQKCQkJaWYoIGRpc1tpXSAhPSBpbmYgKSBjb3V0IDw8IGRpc1tpXSA8PCcgJzsKCQkJZWxzZSBjb3V0IDw8IC0xIDw8ICcgJzsKCQl9CgkJY291dCA8PCBlbmRsIDsKCgkJZm8oaSwxLG4rMSkgYWRqW2ldLmNsZWFyKCk7IC8vIGNsZWFyaW5nIGFkamFjZW5jeSBsaXN0IGZvciBuZXh0IHRlc3QgY2FzZQoKfQoKaW50MzJfdCBtYWluKCkKewkKCWlvczo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKCWludCB0PTE7IAoJY2luPj50OwoJdGVzdCh0KSBnbygpOwp9