Šajā piemērā jūs iemācīsities atrast matricas transponēšanu C programmēšanā.
Lai saprastu šo piemēru, jums vajadzētu būt zināšanām par šādām C programmēšanas tēmām:
- C Masīvi
- C Daudzdimensionāli masīvi
Matricas transponēšana ir jauna matrica, ko iegūst, apmainot rindas un kolonnas.
Šajā programmā lietotājam tiek lūgts ievadīt rindu r un kolonnu c skaitu. Viņu vērtībām šajā programmā jābūt mazākām par 10.
Pēc tam lietotājam tiek lūgts ievadīt matricas elementus (secībā r*c
).
Tālāk norādītā programma aprēķina matricas transponēšanu un izdrukā to uz ekrāna.
Programma Matricas transponēšanas atrašanai
#include int main() ( int a(10)(10), transpose(10)(10), r, c, i, j; printf("Enter rows and columns: "); scanf("%d %d", &r, &c); // Assigning elements to the matrix printf("Enter matrix elements:"); for (i = 0; i < r; ++i) for (j = 0; j < c; ++j) ( printf("Enter element a%d%d: ", i + 1, j + 1); scanf("%d", &a(i)(j)); ) // Displaying the matrix a()() printf("Entered matrix: "); for (i = 0; i < r; ++i) for (j = 0; j < c; ++j) ( printf("%d ", a(i)(j)); if (j == c - 1) printf(""); ) // Finding the transpose of matrix a for (i = 0; i < r; ++i) for (j = 0; j < c; ++j) ( transpose(j)(i) = a(i)(j); ) // Displaying the transpose of matrix a printf("Transpose of the matrix:"); for (i = 0; i < c; ++i) for (j = 0; j < r; ++j) ( printf("%d ", transpose(i)(j)); if (j == r - 1) printf(""); ) return 0; )
Rezultāts
Ievadiet rindas un kolonnas: 2 3 Ievadiet matricas elementus: Ievadiet elementu a11: 1 Ievadiet elementu a12: 4 Ievadiet elementu a13: 0 Ievadiet elementu a21: -5 Ievadiet elementu a22: 2 Ievadiet elementu a23: 7 Ievadīto matricu: 1 4 0 -5 2 7 Matricas transponēšana: 1 -5 4 2 0 7