Untitled
unknown
plain_text
a year ago
908 B
3
Indexable
Never
#include<bits/stdc++.h> using namespace std; const int N = 1e5; vector<int> adj[N]; bool vis[N]; int level[N]; void bfs(int source){ queue<int> que; que.push(source); vis[source] = true; while(!que.empty()){ int par = que.front(); que.pop(); for(auto x : adj[par]){ if(vis[x]) continue; que.push(x); vis[x] = true; level[x]=level[par]+6; } } } int main(){ int t; cin>>t; while(t--){ int v,e; cin >> v >> e; for(int i=1;i<=e;i++){ int v1,v2; cin >> v1 >> v2; adj[v1].push_back(v2); adj[v2].push_back(v1); } int src; cin>>src; bfs(src); for(int i=1;i<=v;i++){ if(i==src)continue; if(level[i]==0)cout<< "-1"<< " "; else cout<<level[i]<<" "; } cout<<endl; } memset(adj,0,sizeof(adj)); memset(level,0,sizeof(level)); memset(vis,0,sizeof(vis)); }