可以通過以下方法來求一個矩陣的轉置:
#include <stdio.h>
#define ROWS 3
#define COLS 3
void transpose(int matrix[ROWS][COLS], int result[COLS][ROWS]) {
for (int i = 0; i < ROWS; i++) {
for (int j = 0; j < COLS; j++) {
result[j][i] = matrix[i][j];
}
}
}
int main() {
int matrix[ROWS][COLS] = {{1, 2, 3},
{4, 5, 6},
{7, 8, 9}};
int result[COLS][ROWS];
transpose(matrix, result);
printf("Original matrix:\n");
for (int i = 0; i < ROWS; i++) {
for (int j = 0; j < COLS; j++) {
printf("%d ", matrix[i][j]);
}
printf("\n");
}
printf("\nTransposed matrix:\n");
for (int i = 0; i < COLS; i++) {
for (int j = 0; j < ROWS; j++) {
printf("%d ", result[i][j]);
}
printf("\n");
}
return 0;
}
在這個程序中,我們首先定義了一個 transpose
函數來求矩陣的轉置。然后在 main
函數中定義了一個 3x3 的矩陣 matrix
,并調用 transpose
函數來求其轉置,并將結果保存在 result
矩陣中。最后分別輸出原始矩陣和轉置后的矩陣。