Advertisement
Guest User

Untitled

a guest
Feb 22nd, 2018
56
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.73 KB | None | 0 0
  1. #include <iostream>
  2. #include <vector>
  3. #include <fstream>
  4. #include <set>
  5.  
  6. using namespace std;
  7.  
  8. int dy[] = {-1, 0, 0, 1};
  9. int dx[] = {0, -1, 1, 0};
  10.  
  11. void floodfill(vector < vector <char> > &v, const int &i, const int &j, const char cA, const int &comp, vector < vector <int> > &n){
  12.     v[i][j] = '*';
  13.  
  14.     n[i][j] = comp;
  15.  
  16.     for(int k = 0; k < 4; k++){
  17.         int i2 = (i + dy[k]);
  18.         int j2 = (j + dx[k]);
  19.  
  20.         if(v[i2][j2] == cA)
  21.             floodfill(v, i2, j2, cA, comp, n);
  22.     }
  23. }
  24.  
  25. int main()
  26. {
  27.     ifstream in("uniformar.in", fstream::in);
  28.     ofstream out("uniformar.out", fstream::out);
  29.  
  30.     int cant, m = 0, comp = 0;
  31.  
  32.     in >> cant;
  33.  
  34.     vector < vector <char> > v((cant + 2), vector <char>((cant + 2), '*'));
  35.     vector < vector <int> > n((cant + 2), vector <int>((cant + 2), (-1)));
  36.  
  37.     for(int i = 1; i <= cant; i++){
  38.         v[i][0] = '*';
  39.  
  40.         for(int j = 1; j <= cant; j++)
  41.             in >> v[i][j];
  42.  
  43.         v[i][cant + 1] = '*';
  44.     }
  45.  
  46.     for(int i = 1; i < int(v.size() - 1); i++){
  47.         for(int j = 1; j < int(v.size() - 1); j++){
  48.             if(v[i][j] != '*'){
  49.                 comp++;
  50.  
  51.                 floodfill(v, i, j, v[i][j], comp, n);
  52.             }
  53.         }
  54.     }
  55.  
  56.     vector < set <int> > adj(comp + 1);
  57.  
  58.     for(int i = 1; i < int(n.size() - 1); i++)
  59.         for(int j = 1; j < int(n.size() - 1); j++)
  60.             if(v[i][j] != (-1))
  61.                 armarLista(v, i, j, v[i][j], comp, n);
  62.  
  63.     cout << "LISTA DE ADYACENCIA: " << endl;
  64.  
  65.     for(int i = 1; i < int(adj.size()); i++){
  66.         cout << i << " | ";
  67.         for(auto j:adj[i])
  68.             cout << j << endl;
  69.         cout << endl;
  70.     }
  71.  
  72.     in.close();
  73.     out.close();
  74.  
  75.     return 0;
  76. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement