0227 - Gen Mat 14: Difference between revisions
Pagină nouă: == Cerința == Scrieţi un program care citeşte de la tastatură un număr natural n şi construieşte în memorie o matrice cu n linii şi n coloane în care ultima linie conţine, în ordine, numerele 1, 2, 3,.., n, elementele situate deasupra diagonalei principale sunt nule şi oricare alt element este obţinut prin însumarea elementelor vecine cu el, aflate pe linia imediat următoare, pe aceeaşi coloană cu el sau pe una din coloanele alăturate. == Date de intrare ==... |
|||
(One intermediate revision by the same user not shown) | |||
Line 4: | Line 4: | ||
Programul citește de la tastatură numărul n. | Programul citește de la tastatură numărul n. | ||
== Date de ieșire == | == Date de ieșire == | ||
Dacă datele sunt introduse corect, pe ecran se va afișa: " Datele de intrare corespund restrictiilor impuse", apoi pe un rand nou va afișa matricea construită, câte o linie a matricei pe câte o linie a ecranului, elementele fiecărei linii fiind separate prin câte un spaţiu. În caz contrar, se va afișa mesajul:" Datele de intrare nu corespund restrictiilor impuse". | |||
== Restricții și precizări == | == Restricții și precizări == | ||
: 3≤n≤15 | : 3≤n≤15 | ||
Line 23: | Line 24: | ||
: Datele de intrare nu corespund restricțiilor impuse. | : Datele de intrare nu corespund restricțiilor impuse. | ||
== Rezolvare == | == Rezolvare == | ||
<syntaxhighlight lang="python" line> | <syntaxhighlight lang="python" line="1"> | ||
#0227 Gen Mat 14 | # 0227 Gen Mat 14 | ||
def verificare_restrictii(nr_linii): | def verificare_restrictii(nr_linii): # functia de verificare a datelor de intrare | ||
if 3 <= nr_linii <= 15: | if 3 <= nr_linii <= 15: | ||
return True | return True | ||
Line 34: | Line 35: | ||
def genmat14(nr_linii): | def genmat14(nr_linii): | ||
matrice = [] | matrice = [] | ||
for i in range(0, nr_linii): # crearea si initializarea matricii patratice | |||
for i in range(0, nr_linii): | |||
linie = [] | linie = [] | ||
for j in range(0, nr_linii): | for j in range(0, nr_linii): | ||
linie.append(0) | linie.append(0) | ||
matrice.append(linie) | matrice.append(linie) | ||
for coloana in range(0, nr_linii): # initializarea ultimei linii cu 1 2 3.. etc | |||
matrice[nr_linii-1][coloana] = coloana + 1 | |||
for linie in range( | for linie in range(nr_linii - 2, -1, -1): # parcurgem liniile in sens invers, de la penultima | ||
for coloana in range( | for coloana in range(nr_linii): | ||
if linie | if linie >= coloana: # daca se afla sub diagonala principala sau pe diagonala | ||
matrice[linie][coloana] = | if coloana == 0: # elementele din prima coloana au doar 2 vecini | ||
matrice[linie][coloana] = matrice[linie+1][coloana] + matrice[linie+1][coloana + 1] | |||
else: # restul au 3 vecini ce pot fi insumati | |||
matrice[linie][coloana] = matrice[linie + 1][coloana] + matrice[linie + 1][coloana - 1] + \ | |||
matrice[linie + 1][coloana + 1] | |||
for linie in matrice: | for linie in matrice: # afisarea | ||
for element in linie: | for element in linie: | ||
print(element, end=" ") | print(element, end=" ") | ||
Line 71: | Line 60: | ||
if __name__ == '__main__': | if __name__ == '__main__': | ||
numar_linii = int(input("Introduceti numarul n ")) | # ne asteptam ca datele de intrare sa fie gresite fapt care ar genera o eroare de tipul ValueError | ||
# pe care o tratam corespunzator | |||
try: | |||
numar_linii = int(input("Introduceti numarul n ")) | |||
if verificare_restrictii(numar_linii): | |||
print("Datele de intrare corespund restrictiilor impuse.") | |||
genmat14(numar_linii) | |||
else: | |||
print("Datele de intrare nu corespund restrictiilor impuse.") | |||
except ValueError: | |||
print("Datele de intrare nu corespund restrictiilor impuse.") | print("Datele de intrare nu corespund restrictiilor impuse.") | ||
</syntaxhighlight> | </syntaxhighlight> |
Latest revision as of 19:12, 29 April 2023
Cerința[edit | edit source]
Scrieţi un program care citeşte de la tastatură un număr natural n şi construieşte în memorie o matrice cu n linii şi n coloane în care ultima linie conţine, în ordine, numerele 1, 2, 3,.., n, elementele situate deasupra diagonalei principale sunt nule şi oricare alt element este obţinut prin însumarea elementelor vecine cu el, aflate pe linia imediat următoare, pe aceeaşi coloană cu el sau pe una din coloanele alăturate.
Date de intrare[edit | edit source]
Programul citește de la tastatură numărul n.
Date de ieșire[edit | edit source]
Dacă datele sunt introduse corect, pe ecran se va afișa: " Datele de intrare corespund restrictiilor impuse", apoi pe un rand nou va afișa matricea construită, câte o linie a matricei pe câte o linie a ecranului, elementele fiecărei linii fiind separate prin câte un spaţiu. În caz contrar, se va afișa mesajul:" Datele de intrare nu corespund restrictiilor impuse".
Restricții și precizări[edit | edit source]
- 3≤n≤15
Exemplu 1[edit | edit source]
- Intrare
- 4
- Ieșire
- Datele introduse corespund restricțiilor impuse.
- 27 0 0 0
- 9 18 0 0
- 3 6 9 0
- 1 2 3 4
Exemplu 2[edit | edit source]
- Intrare
- 67
- Ieșire
- Datele de intrare nu corespund restricțiilor impuse.
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line="1">
- 0227 Gen Mat 14
def verificare_restrictii(nr_linii): # functia de verificare a datelor de intrare
if 3 <= nr_linii <= 15: return True else: return False
def genmat14(nr_linii):
matrice = [] for i in range(0, nr_linii): # crearea si initializarea matricii patratice linie = [] for j in range(0, nr_linii): linie.append(0) matrice.append(linie)
for coloana in range(0, nr_linii): # initializarea ultimei linii cu 1 2 3.. etc matrice[nr_linii-1][coloana] = coloana + 1
for linie in range(nr_linii - 2, -1, -1): # parcurgem liniile in sens invers, de la penultima for coloana in range(nr_linii): if linie >= coloana: # daca se afla sub diagonala principala sau pe diagonala if coloana == 0: # elementele din prima coloana au doar 2 vecini matrice[linie][coloana] = matrice[linie+1][coloana] + matrice[linie+1][coloana + 1] else: # restul au 3 vecini ce pot fi insumati matrice[linie][coloana] = matrice[linie + 1][coloana] + matrice[linie + 1][coloana - 1] + \ matrice[linie + 1][coloana + 1]
for linie in matrice: # afisarea for element in linie: print(element, end=" ") print()
if __name__ == '__main__':
# ne asteptam ca datele de intrare sa fie gresite fapt care ar genera o eroare de tipul ValueError # pe care o tratam corespunzator try: numar_linii = int(input("Introduceti numarul n ")) if verificare_restrictii(numar_linii): print("Datele de intrare corespund restrictiilor impuse.") genmat14(numar_linii) else: print("Datele de intrare nu corespund restrictiilor impuse.") except ValueError: print("Datele de intrare nu corespund restrictiilor impuse.")
</syntaxhighlight>