Advertisement
Josif_tepe

Untitled

Oct 21st, 2022
856
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.10 KB | None | 0 0
  1. #include <iostream>
  2. #include <queue>
  3. using namespace std;
  4.  
  5. int main() {
  6.     int n, m;
  7.     cin >> n >> m;
  8.     char mat[n][m];
  9.     bool visited[n][m];
  10.     for(int i = 0; i < n; i++) {
  11.         for(int j = 0; j < m; j++) {
  12.             cin >> mat[i][j];
  13.         }
  14.     }
  15.    
  16.     for(int i = 0; i < n; i++) {
  17.         for(int j = 0; j < m; j++) {
  18.             visited[i][j] = false;
  19.         }
  20.     }
  21.     int rooms = 0;
  22.     for(int i = 0; i < n; i++) {
  23.         for(int j = 0; j < m; j++) {
  24.             if(mat[i][j] == '.' and !visited[i][j]) {
  25.                 rooms++;
  26.                 queue<int> Q;
  27.                 Q.push(i);
  28.                 Q.push(j);
  29.                
  30.                 visited[i][j] = true;
  31.                
  32.                 while(!Q.empty()) { // Q.size() > 0
  33.                     int ci = Q.front();
  34.                     Q.pop();
  35.                     int cj = Q.front();
  36.                     Q.pop();
  37.                    
  38.                     if(ci + 1 < n and mat[ci + 1][cj] != '#' and !visited[ci + 1][cj]) {
  39.                         Q.push(ci + 1);
  40.                         Q.push(cj);
  41.                         visited[ci + 1][cj] = true;
  42.                     }
  43.                    
  44.                     if(ci - 1 >= 0 and mat[ci - 1][cj] != '#' and !visited[ci - 1][cj]) {
  45.                         Q.push(ci - 1);
  46.                         Q.push(cj);
  47.                         visited[ci - 1][cj] = true;
  48.                     }
  49.                     if(cj + 1 < m and mat[ci][cj + 1] != '#' and !visited[ci][cj + 1]) {
  50.                         Q.push(ci);
  51.                         Q.push(cj + 1);
  52.                         visited[ci][cj + 1] = true;
  53.                     }
  54.                     if(cj - 1 >= 0 and mat[ci][cj - 1] != '#' and !visited[ci][cj - 1]) {
  55.                         Q.push(ci);
  56.                         Q.push(cj - 1);
  57.                         visited[ci][cj - 1] = true;
  58.                     }
  59.                 }
  60.                
  61.             }
  62.         }
  63.     }
  64.     cout << rooms << endl;
  65.     return 0;
  66. }
  67. /*
  68.  
  69.  ########
  70.  #..#...#
  71.  ####.#.#
  72.  #..#...#
  73.  ########
  74.  
  75.  **/
  76.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement