В этом примере вы научитесь находить транспонирование матрицы в программировании на C.
Чтобы понять этот пример, вы должны знать следующие темы программирования на C:
- Массивы C
- C Многомерные массивы
Транспонирование матрицы - это новая матрица, которая получается путем обмена строками и столбцами.
В этой программе пользователя просят ввести количество строк r и столбцов c. Их значения в этой программе должны быть меньше 10.
Затем пользователя просят ввести элементы матрицы (порядка r*c
).
Программа ниже вычисляет транспонирование матрицы и выводит ее на экран.
Программа для поиска транспонирования матрицы
#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; )
Вывод
Введите строки и столбцы: 2 3 Введите элементы матрицы: Введите элемент a11: 1 Введите элемент a12: 4 Введите элемент a13: 0 Введите элемент a21: -5 Введите элемент a22: 2 Введите элемент a23: 7 Введите матрицу: 1 4 0-5 2 7 Транспонирование матрицы: 1-5 4 2 0 7