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
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;
}
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
Alte întrebări interesante
Matematică,
8 ani în urmă
Matematică,
8 ani în urmă
Religie,
8 ani în urmă
Limba română,
9 ani în urmă
Limba română,
9 ani în urmă
Limba română,
9 ani în urmă
Matematică,
9 ani în urmă