要实现矩阵的转置,可以使用二维数组来表示矩阵。以下是一个示例代码:
#include#define ROW 3 #define COL 3 void transpose(int matrix[ROW][COL], int result[COL][ROW]) { for (int i = 0; i < ROW; i++) { for (int j = 0; j < COL; j++) { result[j][i] = matrix[i][j]; } } } int main() { int matrix[ROW][COL] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}}; int result[COL][ROW]; transpose(matrix, result); printf("Original Matrix:\n"); for (int i = 0; i < ROW; i++) { for (int j = 0; j < COL; j++) { printf("%d ", matrix[i][j]); } printf("\n"); } printf("\nTransposed Matrix:\n"); for (int i = 0; i < COL; i++) { for (int j = 0; j < ROW; j++) { printf("%d ", result[i][j]); } printf("\n"); } return 0; }
在上面的示例代码中,我们定义了一个函数transpose
来实现矩阵的转置。该函数接受两个参数,分别是原始矩阵和转置结果矩阵。函数中使用两个嵌套循环来遍历原始矩阵的每个元素,并将其赋值给转置结果矩阵对应位置的元素。
在main
函数中,我们定义了一个3x3的矩阵matrix
,并调用transpose
函数来计算矩阵的转置。最后,我们使用两个嵌套循环来分别打印原始矩阵和转置后的矩阵。