Cerința
Se citeşte din fişierul de intrare o matrice pătratică A
cu n
linii şi n
coloane conţinând numere naturale. Scrieţi un program care modifică matricea A
în modul următor:
I. interschimbă elementele matricei din triunghiul superior cu cele din triunghiul inferior al matricei
II. după aceea interschimbă elementele superprime distincte, care apar în triunghiul din dreapta cu cel din triunghiul din stânga al matricei (ambele elemente trebuie să fie superprime);
Un număr natural n
se numeşte superprim dacă printre numerele care pot fi obţinute mutând, pe rând, prima cifră a numărului n
şi a celor obţinute pe parcurs, pe ultima poziţie, există cel puţin un număr prim. De exemplu 124
este “superprim” deoarece dintre numerele 241
, 412
şi 124
, numărul 241
este prim. 15
nu este “superprim” deoarece nici 51
, nici 15
nu sunt numere prime.
Date de intrare
Fișierul de intrare matrice.in
conține pe prima linie numărul n
, iar pe următoarele n
linii câte n
numere naturale reprezentând elementele matricei.
Date de ieșire
Fișierul de ieșire matrice.out
va conține matricea modificată, câte o linie a matricei pe o linie a fişierului, fiecare element al matricei fiind separat prin câte un spaţiu.
Restricții și precizări
3 ≤ n ≤ 50
1 ≤ a
i,j
≤ 2000
- Nu se iau în considerare elementele de pe cele două diagonale.
Exemplu:
matrice.in
4 1 3 4 2 8 1 2 7 124 2 1 32 2 5 6 1
matrice.out
1 5 6 2 8 1 2 7 32 2 1 124 2 3 4 1
Explicații
Pentru n=4 şi matricea A=[1342812712421322561], după aplicarea interschimbării de la punctul I. se obţine matricea A=[1562812712421322341], apoi aplicând modificarea de la punctul II. se obţine A=[1562812732211242341] (matricea afişată). Observăm că elementele 8 şi 7 nu se schimbă, deoarece 8 nu este superprim, dar 124 şi 32 se schimbă între ele deoarece ambele sunt superprime.
În figura de mai jos, triunghiul superior al matricei este cel marcat cu 1, triunghiul inferior este cel marcat cu 3, triunghiul din stânga este cel marcat cu 2, iar triunghiul din dreapta este cel marcat cu 4.
Pentru n=4, triunghiul superior al matricei A conţine elementele a12 şi a13, triunghiul inferior conţine elementele a42 şi a43, triunghiul stâng conţine elementele a21 şi a31, iar triunghiul drept conţine elementele a24 şi a34.
#include<fstream> using namespace std; ifstream cin("matrice.in"); ofstream cout("matrice.out"); int prim(int n) { if(n == 0 || n == 1) return 0; if(n == 2) return 1; if(n % 2 == 0) return 0; for(int i = 3 ; i * i <= n ; i += 2) if(n % i == 0) return 0; return 1; } int put(int n) { int p = 1; while(n != 0) { p *= 10; n /= 10; } return p; } int super(int n) { int aux = n; int putere = put(n / 10); while(n != 0) { aux = putere * (aux % 10) + aux / 10; if(prim(aux)) return 1; n /= 10; } return 0; } int main() { int n , a[52][52]; cin >> n; for(int i = 1 ; i <= n ; i++) for(int j = 1 ; j <= n ; j++) cin >> a[i][j]; for(int i = 1 ; i <= n ; i++) for(int j = 1 ; j <= n ; j++) if(i < j && i + j <= n) swap(a[i][j] , a[n-i+1][j]); for(int i = 1 ; i <= n ; i++) for(int j = 1 ; j <= n ; j++) if(i > j && i + j <= n) if(super(a[i][j])==1 && super(a[i][n-j+1])==1) swap(a[i][j] , a[i][n-j+1]); for(int i = 1 ; i <= n ; i++) { for(int j = 1 ; j <= n ; j++) cout << a[i][j] << ' '; cout << endl; } return 0; }