Advertisement
tungSfer

Untitled

May 16th, 2021
233
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.32 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2.  
  3. #define ll long long
  4. #define el endl
  5. #define umi unordered_map<int, int>
  6. #define umll unordered_map<ll, ll>
  7. #define all(vect) vect.begin(), vect.end()
  8. #define reset(A) memset(A, 0, sizeof(A))
  9.  
  10. const int mod = 1e9 + 7;
  11.  
  12. using namespace std;
  13.  
  14. int v[1005][1005];
  15. int n, m;
  16. bool check[1005];
  17. void khoitao(){
  18.     for(int i=1;i<=n;i++) check[i]=0;
  19. }
  20. void dfs(int u){
  21.     check[u] = 1;
  22.     for(int i = 1; i <= n; i++)
  23.         if(v[u][i] && check[i] == 0)
  24.             dfs(i);
  25. }
  26.  
  27. int ktcanhcau(){
  28.     khoitao();
  29.     dfs(1);
  30.     for(int i=1;i<=n;i++){
  31.         if(check[i]==0) return 1;
  32.     }
  33.     return 0;
  34. }
  35.  
  36. void solve()
  37. {
  38.     cin >> n >> m;
  39.     reset(v);
  40.     int x, y;
  41.     for(int i = 0; i < m; i++)
  42.     {
  43.         cin >> x >> y;
  44.         v[x][y] = 1;
  45.         v[y][x] = 1;
  46.     }
  47.     for(int i = 1; i < n; i++)
  48.     {
  49.         for(int j = i + 1; j <= n; j++)
  50.         {
  51.             if(v[i][j]==1)
  52.             {
  53.                 v[i][j] = v[j][i] = 0;
  54.                 if(ktcanhcau()==1)
  55.                 {
  56.                     cout << i << " " << j << " ";
  57.                 }
  58.                 v[i][j] = v[j][i] = 1;
  59.             }
  60.                
  61.         }
  62.            
  63.     }
  64.     cout << el;
  65. }
  66.  
  67. int main(){
  68.     int t ;
  69.     cin >> t;
  70.     while(t--)
  71.     {
  72.         solve();
  73.     }
  74.     return 0;
  75. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement