Advertisement
Georgiy031

Untitled

May 4th, 2020
76
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.08 KB | None | 0 0
  1. #include <iostream>
  2. #include <vector>
  3. using namespace std;
  4.  
  5. int n, m;
  6. vector <vector <int> > graf;
  7. vector <int> colours;
  8. vector <int> cycle;
  9.  
  10. bool dfs(int v) {
  11.     colours[v] = 2;
  12.     for (int i = 0; i < graf[v].size(); i++) {
  13.         if (colours[graf[v][i]] == 1) {
  14.             if (dfs(graf[v][i])) {
  15.                 cycle.push_back(v);
  16.                 return true;
  17.             }
  18.         }
  19.         else if (colours[graf[v][i]] == 2) {
  20.             cycle.push_back(v);
  21.             return true;
  22.         }
  23.     }
  24.     colours[v] = 3;
  25.     return false;
  26. }
  27.  
  28. int main() {
  29.     cin >> n >> m;
  30.     graf.resize(n);
  31.     colours.resize(n);
  32.     int v1, v2;
  33.     colours.assign(n, 1);
  34.     for (int i = 0; i < m; i++) {
  35.         cin >> v1 >> v2;
  36.         graf[v1 - 1].push_back(v2 - 1);
  37.     }
  38.     int t = 0;
  39.     for (int i = 0; i < n; i++) {
  40.         if (colours[i] == 1 && dfs(i)) {
  41.             t = 1;
  42.             break;
  43.         }
  44.     }
  45.     if (t == 0) cout << "NO";
  46.     else {
  47.         cout << "YES\n";
  48.         for (int i = cycle.size() - 1; i >= 0; --i) {
  49.             cout << cycle[i] + 1 << " ";
  50.         }
  51.     }
  52.     return 0;
  53. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement