0993 - Gen Mat 20
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 fiecare linie a matricei să conţină o permutare a mulţimii {1,2,...,n}, astfel încât pe linii diferite ale matricei să se afle permutări diferite.
Date de intrare
Programul citește de la tastatură numărul n.
Date de ieșire
Programul afișează pe ecran 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.
Restricții și precizări
- 3 ≤ n ≤ 15
- orice matrice afișată care respectă condițiile problemei este corectă
Exemplul 1
- Intrare
- 4
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 2 4 1 3
- 3 2 1 4
- 1 2 4 3
- 1 4 2 3
Exemplul 2
- Intrare
- 2
- Ieșire
- Datele de intrare nu corespund restricțiilor impuse.
Rezolvare
<syntaxhighlight lang="python" line="">
- 0993 - Gen Mat 20
import random
def construieste_matrice(n):
A = [] for i in range(n): permutare = list(range(1, n+1)) random.shuffle(permutare) A.append(permutare) return A
if __name__ == "__main__":
n = int(input("Introduceti n: ")) if n < 3 or n > 15: print("Datele de intrare nu corespund restricțiilor impuse.") else: print("Datele de intrare corespund restricțiilor impuse.") A = construieste_matrice(n) for rand in A: print(" ".join(str(x) for x in rand))
</syntaxhighlight>