👤

Se dă o matrice cu n linii și m coloane și elemente 0 sau 1, care reprezintă harta unei planete, în care 1 înseamnă uscat, iar 0 înseamnă apă. Două elemente 1 care se învecinează pe linie sau pe coloană (nu și pe diagonală) fac parte din același continent.

Să se determine câte continente sunt pe hartă.

Date de intrare
Fișierul de intrare fill.in conține pe prima linie numerele n m. Următoarele n linii conțin câte m elemente, 0 sau 1, cu semnificația din enunț.

Date de ieșire
Fișierul de ieșire fill.out va conține pe prima linie numărul C de continente existente.

Restricții și precizări
1 ≤ n , m ≤ 100


Răspuns :

#include <iostream>
using namespace std;

int a[102][102];

void fill(int i, int j, int c)
{
    a[i][j] = c;
    if(a[i-1][j] == 1)
      fill(i-1, j, c);
    if(a[i][j+1] == 1)
      fill(i, j+1, c);
    if(a[i+1][j] == 1)
      fill(i+1, j, c);
    if(a[i][j-1] == 1)
      fill(i, j-1, c);
}

int main()
{
    int n, m, c = 0;
    cin >> n >> m;
    for(int i = 1; i <= n; i++)
        for(int j = 1; j <=m; j++)
            cin >> a[i][j];
    for(int i = 1; i <= n; i++)
        for(int j = 1; j <= m; j++)
            if(a[i][j] == 1)
            {
                c++;
                fill(i, j, c + 1);
            }
    cout << c;
    return 0;
}