面试题答案
一键面试#include <stdio.h>
// 矩阵转置函数
void transposeMatrix(int (*matrix)[], int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = i + 1; j < cols; j++) {
int temp = *(*(matrix + i) + j);
*(*(matrix + i) + j) = *(*(matrix + j) + i);
*(*(matrix + j) + i) = temp;
}
}
}
// 打印矩阵函数
void printMatrix(int (*matrix)[], int rows, int cols) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
printf("%d ", *(*(matrix + i) + j));
}
printf("\n");
}
}
你可以使用以下方式调用这个函数:
int main() {
int matrix[3][3] = {
{1, 2, 3},
{4, 5, 6},
{7, 8, 9}
};
int rows = 3;
int cols = 3;
printf("原始矩阵:\n");
printMatrix(matrix, rows, cols);
transposeMatrix(matrix, rows, cols);
printf("转置后的矩阵:\n");
printMatrix(matrix, rows, cols);
return 0;
}
在上述代码中:
transposeMatrix
函数实现了矩阵的原地转置。通过两重循环遍历矩阵,交换matrix[i][j]
和matrix[j][i]
的值,注意内层循环从i + 1
开始,以避免重复交换。printMatrix
函数用于打印矩阵,方便查看转置前后的矩阵。- 在
main
函数中,定义了一个矩阵并调用transposeMatrix
进行转置,然后使用printMatrix
打印转置前后的矩阵。
请注意,在C语言中,函数参数如果是二维数组,第二维的大小必须明确指定,所以代码中使用了 int (*matrix)[]
的形式,实际调用时编译器会根据传入数组的第二维大小来正确处理。