c语言实现两个矩阵相乘
时间: 2023-11-25 10:05:02 浏览: 79
下面是C语言实现两个矩阵相乘的示例代码:
```c
#include <stdio.h>
#define ROW 2
#define COL 3
void matrix_multiply(int mat1[][COL], int mat2[][COL], int result[][COL])
{
for (int i = 0; i < ROW; i++) {
for (int j = 0; j < COL; j++) {
result[i][j] = 0;
for (int k = 0; k < COL; k++) {
result[i][j] += mat1[i][k] * mat2[k][j];
}
}
}
}
int main()
{
int mat1[ROW][COL] = {{1, 2, 3}, {4, 5, 6}};
int mat2[ROW][COL] = {{7, 8, 9}, {10, 11, 12}};
int result[ROW][COL];
matrix_multiply(mat1, mat2, result);
printf("Result matrix:\n");
for (int i = 0; i < ROW; i++) {
for (int j = 0; j < COL; j++) {
printf("%d ", result[i][j]);
}
printf("\n");
}
return 0;
}
```
这个示例代码中,我们定义了两个2x3的矩阵mat1和mat2,以及一个空的2x3的矩阵result用于存储结果。然后我们调用matrix_multiply函数,将mat1和mat2作为参数传递给它,并把结果存储在result矩阵中。
在matrix_multiply函数中,我们使用了三重循环来计算矩阵乘积。外层循环遍历mat1的行,内层循环遍历mat2的列,而最内层循环则对应着矩阵乘法中的求和操作。具体来说,对于每个(i, j)位置的元素,我们将mat1的第i行和mat2的第j列对应位置相乘,并将它们的乘积累加到result[i][j]中。
最后,我们在主函数中打印出result矩阵的内容,以验证矩阵乘积的正确性。
阅读全文