Cerința
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
Exemplu
fill.in
4 6 1 1 1 0 1 0 0 0 1 0 1 1 1 1 1 0 0 0 0 1 0 1 1 1
fill.out
3
Explicație
Cele 3
continente sunt evidenţiate mai jos:
#include <bits/stdc++.h> using namespace std; ifstream cin("fill.in"); ofstream cout("fill.out"); int a[501][501]; void fill(int i, int j){ a[i][j] = 0; if(a[i+1][j] == 1) fill(i+1, j); if(a[i-1][j] == 1) fill(i-1, j); if(a[i][j+1] == 1) fill(i, j+1); if(a[i][j-1] == 1) fill(i, j-1); } /* 5 6 1 1 0 0 1 1 0 1 0 1 1 0 0 1 1 0 0 1 0 0 0 0 0 0 1 1 1 1 1 1 */ int main(){ int n, m, insule = 0; cin >> n >> m; for(int i = 1; i <= n; ++i) for(int j = 1; j <= m; ++j) cin >> a[i][j]; /// va avea valoarea 1 pt uscat si 0 pentru apa for(int i = 1; i <= n; ++i) for(int j = 1; j <= m; ++j) if(a[i][j] == 1){ insule++; fill(i, j); } cout << insule; return 0; }