0212 - Max Min Matrice
Sursa: [1]
Enunt
Se consideră tabloul bidimensional cu m linii şi n coloane ce conţine numere naturale cu cel mult patru cifre fiecare.
Cerinţa
Să se determine cea mai mică valoare de pe fiecare linie, iar dintre acestea să se determine valoarea maximă.
Date de intrare
Fişierul de intrare maxminmatrice.in conţine pe prima linie numerele m şi n, iar pe următoarele m linii câte n numere naturale separate prin spaţii, reprezentând elementele tabloului.
Date de ieșire
Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse.". Fişierul de ieşire maxminmatrice.out va conţine pe prima linie numărul cerut, cea mai mare valoare dintre minimele de pe linii. În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, programul va afișa "Datele de intrare nu corespund restricțiilor impuse.".
Restricţii şi precizări
- 2 ≤ m, n ≤ 23
- elementele tabloului sunt mai mici decât 1000.
Exemple
Exemplu 1
- maxminmatrice.in
- 3 5
- 3 2 7 13 5
- 10 9 12 6 9
- 7 4 5 6 3
- maxminmatrice.out
- 6
Explicatie
Minimele de pe cele trei linii sunt: 2 6 3. Dintre acestea, cea mai mare valoare este 6.
Rezolvare
<syntaxhighlight lang="python" line> def citire_matrice():
try: n = int(input("Introduceti numarul de linii: ")) m = int(input("Introduceti numarul de coloane: ")) if m % 2 == 0: print("Numarul de coloane trebuie sa fie impar.") exit() if 2 <= n <= 23 and 2 <= m <= 23: print("Datele sunt corecte.") else: print("Datele nu sunt conform restrictiilor impuse.") exit() except ValueError: print("Trebuie introduse doar numere intregi.") exit()
matrice = [] for linie in range(n): linie_matrice = [] for coloana in range(m): try: valoare = int(input(f"Introduceti un numar pentru linia {linie+1}, coloana {coloana+1}: ")) if valoare <= 1000: print("Datele sunt corecte.") linie_matrice.append(valoare) else: print("Datele nu sunt conform restrictiilor impuse.") exit() except ValueError: print("Trebuie introduse doar numere intregi.") exit() matrice.append(linie_matrice)
return n, m, matrice
def maxminmatrice():
with open("maxminmatrice.in", "r") as fin: n, m = map(int, fin.readline().split()) a = [] for i in range(n): mini = 1001 row = list(map(int, fin.readline().split())) for j in range(m): if row[j] < mini: mini = row[j] a.append(row) fin.close()
v = [] for i in range(n): v.append(min(a[i]))
v.sort() with open("maxminmatrice.out", "w") as fout: fout.write(str(v[-1])) fout.close()
if _name_ == "_main_":
maxminmatrice()
</syntaxhighlight>
Explicații
Acest cod realizează două funcții: citire_matrice() și maxminmatrice(), și o verificare if _name_ == "_main_": pentru a rula maxminmatrice() atunci când fișierul este executat direct.
Funcția citire_matrice() citeste datele de intrare de la tastatură și construiește o matrice, aplicând anumite restricții impuse pentru a verifica validitatea datelor introduse. Funcția întoarce dimensiunile matricei și matricea propriu-zisă.
Funcția maxminmatrice() citeste datele de intrare din fișierul "maxminmatrice.in" și calculează cea mai mică valoare de pe fiecare linie, iar dintre acestea calculează valoarea maximă. Rezultatul este scris în fișierul "maxminmatrice.out".