Advertisement
Guest User

B(dfs)

a guest
Jan 19th, 2020
346
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.16 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2.  
  3. using namespace std;
  4.  
  5. const int MAXN = 1e5 + 1;
  6.  
  7. vector <int> g[MAXN], ans;
  8. short col[MAXN], cur_col = 1; // 0 - unvisited, 1 - part 1, 2 - part 2
  9.  
  10. bool dfs(int v) // Поиск в глубину (true - Ok, false - цикл)
  11. {
  12.     col[v] = cur_col;
  13.     cur_col = cur_col % 2 + 1; //swap colors
  14.     for(int to : g[v])
  15.     {
  16.         if(col[to] and col[to] != cur_col or col[to] == 0 and !dfs(to))
  17.            return false;
  18.     }
  19.     cur_col = cur_col % 2 + 1; //swap colors
  20.     return true;
  21. }
  22.  
  23. string solve(int n)
  24. {
  25.     for(int i = 1; i <= n; i++)
  26.         if(col[i] == 0 and !dfs(i))
  27.         {
  28.             return "NO";
  29.         }
  30.     return "BIPARTITE";
  31. }
  32.  
  33. int main()
  34. {
  35.     // Ускорение ввода
  36.     ios_base::sync_with_stdio(0);
  37.     cin.tie(0);
  38.     cout.tie(0);
  39.  
  40.     // Ввод/вывод из файла
  41.     freopen("input.txt", "r", stdin);
  42.     freopen("output.txt", "w", stdout);
  43.  
  44.     // Ввод
  45.     int n, m;
  46.     cin >> n >> m;
  47.     while(m--)
  48.     {
  49.         int a, b;
  50.         cin >> a >> b;
  51.         g[a].push_back(b);
  52.         g[b].push_back(a);
  53.     }
  54.  
  55.     cout << solve(n);
  56.  
  57.     return 0;
  58. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement