/***************************************************************** * Ovo delo zaštićeno je licencom Creative Commons CC BY-NC-ND 4.0 * (Attribution-NonCommercial-NoDerivatives 4.0 International License). * Za detalje pogledati LICENSE.TXT * Autori: Milena Vujosevic Janicic, Jovana Kovacevic, * Danijela Simic, Andjelka Zecevic, Aleksandra Kocic ******************************************************************/ #include #include #define MAKS 50 /* Funkcija ucitava elemente matrice dimenzije mxn. */ void ucitaj(int a[][MAKS], int m, int n) { int i, j; printf("Unesite elemente matrice:\n"); for (i = 0; i < m; i++) for (j = 0; j < n; j++) scanf("%d", &a[i][j]); } /* Funkcija ispisuje elemente matrice dimenzije mxn. */ void ispisi(int a[][MAKS], int m, int n) { int i, j; for (i = 0; i < m; i++) { for (j = 0; j < n; j++) printf("%d ", a[i][j]); printf("\n"); } } /* Funkcija formira maticu t transponovanjem matrice a. */ void transponovana(int a[][MAKS], int m, int n, int t[][MAKS]) { int i, j; for (i = 0; i < m; i++) for (j = 0; j < n; j++) t[j][i] = a[i][j]; } int main() { /* Deklaracije potrebnih promenljivih. */ int a[MAKS][MAKS], t[MAKS][MAKS]; int m, n; /* Ucitavanje dimenzije matrice i provera ispravnosti ulaza. */ printf("Unesite broj vrsta i broj kolona matrice: "); scanf("%d%d", &m, &n); if (n <= 0 || n > MAKS || m <= 0 || m > MAKS) { printf("Greska: neispravan unos.\n"); exit(EXIT_FAILURE); } /* Ucitavanje elemenata matrice. */ ucitaj(a, m, n); /* Formiranje transponovane matrice. */ transponovana(a, m, n, t); /* Ispis rezultata. */ printf("Transponovana matrica je:\n"); ispisi(t, n, m); exit(EXIT_SUCCESS); }