Advertisement
NikolayChukanov

A

Mar 7th, 2023
754
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.80 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2.  
  3. using namespace std;
  4.  
  5. using graph = vector<vector<int>>;
  6.  
  7. vector<int> cnt;
  8. vector<char> visited;
  9.  
  10. void dfs(int u, int p, const graph & g, int& counter){
  11.   if (visited[u]){
  12.     return;
  13.   }
  14.   visited[u] = true;
  15.   cnt[u] = counter;
  16.   ++counter;
  17.   for (int v : g[u]){
  18.     if (v != p){
  19.       dfs(v, u, g, counter);
  20.     }
  21.   }
  22. }
  23.  
  24. int main(){
  25.   ios::sync_with_stdio(false);
  26.   cin.tie(0);
  27.  
  28.   int n, m, s;
  29.   cin >> n >> m >> s;
  30.   graph g(n);
  31.  
  32.   for (int i = 0; i < m; ++i){
  33.     int u, v;
  34.     cin >> u >> v;
  35.     --u;
  36.     --v;
  37.     g[u].push_back(v);
  38.     g[v].push_back(u);
  39.   }
  40.   --s;
  41.   cnt.resize(n,-1);
  42.   visited.resize(n, 0);
  43.   int counter = 0;
  44.   dfs(s, s, g, counter);
  45.   for (int el : cnt){
  46.     cout << el << " ";
  47.   }
  48.   cout << endl;
  49.  
  50.  
  51. }
  52.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement