Informatică, întrebare adresată de Utilizator anonim, 9 ani în urmă

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ăspunsuri la întrebare

Răspuns de rossetta
3
#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;
}



Utilizator anonim: primesc 0 puncte pe pb info
rossetta: trebuie sa pui fisiere
rossetta: eu folosesc alta sintaxa pentru fisiere si le-am sters
Alte întrebări interesante