C 语言矩阵转置:示例代码和解释
以下是用 C 语言编写矩阵的转置的示例代码:
#include <stdio.h>
#define ROWS 3
#define COLS 3
void transpose(int matrix[ROWS][COLS], int result[COLS][ROWS]) {
int i, j;
for(i = 0; i < ROWS; i++) {
for(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];
int i, j;
transpose(matrix, result);
printf("Original matrix:\n");
for(i = 0; i < ROWS; i++) {
for(j = 0; j < COLS; j++) {
printf("%d ", matrix[i][j]);
}
printf("\n");
}
printf("\nTransposed matrix:\n");
for(i = 0; i < COLS; i++) {
for(j = 0; j < ROWS; j++) {
printf("%d ", result[i][j]);
}
printf("\n");
}
return 0;
}
在这个示例中,我们定义了一个 transpose 函数,该函数接受一个 ROWS 行 COLS 列的矩阵和一个 COLS 行 ROWS 列的矩阵作为参数,将第一个矩阵转置后存储到第二个矩阵中。我们还定义了一个 main 函数来测试 transpose 函数。在 main 函数中,我们首先定义了一个 ROWS 行 COLS 列的矩阵 matrix,并将其初始化为一个简单的 3x3 矩阵。然后,我们定义了一个 COLS 行 ROWS 列的矩阵 result,并将其传递给 transpose 函数进行转置。最后,我们在控制台上打印出原始矩阵和转置后的矩阵。
原文地址: https://www.cveoy.top/t/topic/o0jv 著作权归作者所有。请勿转载和采集!