fbpx

Problema #81 – Matrice – Rezolvari PBInfo

de Mihai-Alexandru

Cerinţa

Scrieţi un program care citeşte de la tastatură un număr natural n ( 1 ≤ n ≤ 20 ) şi apoi elementele unui tablou bidimensional cu n linii şi n coloane, care memorează numere naturale.

Programul afişează pe ecran numărul de elemente din tablou care sunt strict mai mari decât toate elementele cu care se învecinează direct (aflate pe aceeaşi linie dar pe o coloană alăturată sau pe aceeaşi coloană dar pe o linie alăturată).

Date de intrare

Programul citește de la tastatură numărul n, iar apoi n*n numere naturale, separate prin spaţii.

Date de ieşire

Programul afișează pe prima linie a ecranului numărul de elemente din tablou care respectă regula.

Restricţii şi precizări

  • 1 ≤ n ≤ 20
  • elementele tabloului sunt mai mici decât 1000

Exemplu

Intrare

4
1 5 1 1
2 1 2 3
1 3 4 2
2 1 2 1

Ieșire

5

Explicații

Elementele din matrice care respectă regula sunt: 5 2 3 4 2

#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n , a[22][22] , cnt = 0;
    cin >> n;
    for(int i = 0 ; i <= n+1 ; ++i)
    {
        for(int j = 0 ; j <= n+1 ; ++j)
        {
            if(i == 0 || i == n + 1 || j == 0 ||j == n + 1) a[i][j] = -1;
            else cin >> a[i][j];
        }
    }
    for(int i = 1 ; i <= n ; ++i)
    {
        for(int j = 1 ; j <= n ; ++j)
        {
            if(a[i][j] > a[i-1][j] && a[i][j] > a[i+1][j] && a[i][j] > a[i][j-1] && a[i][j] > a[i][j+1])
            cnt++;
        }
    }
    cout << cnt;
    return 0;

}
Comentarii

S-ar putea sa iti placa