3264 - Sum Min XI

From Bitnami MediaWiki

Cerinţa

Se dă o matrice pătratică cu n lini şi n coloane şi elemente numere întregi. Determinaţi cea mai mică sumă a n elemente din matrice, obținută adunând câte un element de pe fiecare coloană a matricei.

Date de intrare

Fişierul de intrare summin_xiin.txt conţine pe prima linie numărul n, iar pe următoarele n linii câte n numere întregi, separate prin spaţii, reprezentând elementele matricei.

Date de ieșire

Fişierul de ieşire summin_xiout.txt va conţine pe prima linie numărul S, reprezentând suma minimă determinată.

Restricţii şi precizări

  • 1 ⩽ n⩽ 100
  • elementele matricei vor avea cel mult 4 cifre

Exemplu 1

summin_xiin.txt
4
12 16 5 4
11 14 6 7
8 2 3 17
10 9 13 15
summin_xiout.txt
Datele de intrare corespund restrictiilor impuse
17


Exemplu 2

summin_xiin.txt
4000
12 16 5 4
11 14 6 7
8 2 3 17
10 9 13 15
summin_xiout.txt
Datele de intrare nu corespund restrictiilor impuse


Explicatie

17=8+2+3+4.

Rezolvare

<syntaxhighlight lang="python" line> def suma_minima(matrice):

   # Calculează suma minimă a elementelor din matrice, adunând câte un element de pe fiecare coloană.
   suma = 0
   for coloana in zip(*matrice):
       suma += min(coloana)
   return suma


def main():

   with open('summin_xiin.txt', 'r') as fin, open('summin_xiout.txt', 'w') as fout:
       n = int(fin.readline().strip())
       matrice = [list(map(int, linie.split())) for linie in fin.readlines()]
       # Verifică dacă datele de intrare respectă restricțiile
       if not (1 <= n <= 100 and all(0 <= x < 10000 for linie in matrice for x in linie)):
           fout.write("Datele de intrare nu corespund restrictiilor impuse\n")
           return
       fout.write("Datele de intrare corespund restrictiilor impuse\n")
       suma = suma_minima(matrice)
       fout.write(f"{suma}\n")


if __name__ == "__main__":

   main()


</syntaxhighlight>