0081 - Matrice

From Bitnami MediaWiki

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

Dacă datele sunt introduse corect,pe ecran se va afișa :"Datele sunt introduse corect.",apoi pe un rând nou numărul de elemente din tablou care respectă regula.În cazul contrar,se va afișa pe ecran "Datele nu corespund restricțiilor impuse.".

Restricții și precizări

  • 1 ⩽ n ⩽ 20
  • elementele matricei vor fi mai mici decât 1.000.000

Exemplu

Intrare
4
1 5 1 1
2 1 2 3
1 3 4 2
2 1 2 1
Date de ieșire
Datele sunt introduse corect.
5

Explicație

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

Rezolvare

<syntaxhighlight lang="python" line>

def validare_date(n, matrice):

   # Verifică dimensiunea matricei
   if n < 1 or n > 20:
       return False
   # Verifică dacă elementele matricei sunt numere naturale
   for linie in matrice:
       for element in linie:
           if not isinstance(element, int) or element < 0:
               return False
   # Datele sunt valide
   return True


def rezolva_problema(n, matrice):

   numar_elemente= 0
   # Verifică fiecare element din matrice
   for i in range(n):
       for j in range(n):
           este_maxim = True
           # Verifică dacă există un element vecin mai mare
           if i > 0 and matrice[i-1][j] > matrice[i][j]:
               este_maxim = False
           if i < n-1 and matrice[i+1][j] > matrice[i][j]:
               este_maxim = False
           if j > 0 and matrice[i][j-1] > matrice[i][j]:
               este_maxim = False
           if j < n-1 and matrice[i][j+1] > matrice[i][j]:
               este_maxim = False
           # Dacă este maxim, crește numărul de elemente găsite
           if este_maxim:
               numar_elemente+= 1
   # Returnează numărul de elemente găsite
   return numar_elemente


if __name__ == '__main__':

   # Citirea datelor de intrare
   n = int(input())
   matrice = []
   for i in range(n):
       linie = [int(x) for x in input().split()]
       matrice.append(linie)
   # Verificarea datelor de intrare
   if not validare_date(n, matrice):
       print("Datele nu corespund restricțiilor impuse.")
   else :
   # Rezolvarea problemei și afișarea rezultatului
       rezultat = rezolva_problema(n, matrice)
       print("Datele sunt introduse corect.")
       print(rezultat)


</syntaxhighlight>