矩阵乘法的前提条件:行列对应(矩阵A3行四列 对应 矩阵B四行3列)
最后运算矩阵C第一个数等于A的第一行每一个数乘以B第一列每一个数
C[0][0]=A[0] [0] * B[0] [0]+A[0] [1] * B[1] [0]+A[0] [2] * B[2] [0]+A[0] [3] * B[3] [0]
C[0] [1]同理
计算出每一个C矩阵的数值,然后输出
- 先输入矩阵A的每一个数值,逐行输入,然后保存在一个多维数组arr1[ ][ ]中
- 矩阵B同理,保存在数组arr2中
- 计算矩阵C的每一个数值,利用嵌套循环加法的方式 sum = sum + arr1[i][m] * arr2[m][j]; 计算出A的每一行乘以B的每一列得出C的第一个数值,然后循环计算出每一个数值,存入在数组arr3中
- 最后输出arr3
#include<stdio.h>
#define ROW 3 //行
#define COL 3 //列
#define MID 4
int main()
{
printf("下面输入分别输入一个3行4列的矩阵A和4行3列的矩阵B\n ") ;
int arr1[ROW][MID] = { 0 }; // 3行4列
int arr2[MID][COL] = { 0 }; // 4行3列
int arr3[ROW][COL] = { 0 }; // 3行3列
int i = 0;
int j = 0;
int m = 0;
printf("第一个矩阵A\n" );
for (i = 0; i < ROW; i++) //输入三次,变成三行
{
printf("第一个矩阵的%d行\n", i);
for (j = 0; j < MID; j++) //输入四次,变成四列
{
scanf("%d", &arr1[i][j]); //第一次一直读入从arr1[0][0]到 arr1[0][4]
}
}
printf("第二个矩阵B\n");
for (i = 0; i < MID; i++) //输入四次,变成四行
{
printf("第二个矩阵第%d行\n", i);
for (j = 0; j < COL; j++) //输入三次,变成三列
{
scanf("%d", &arr2[i][j]);//第一次一直读入从arr2[0][0]到 arr2[0][4]
}
}
printf("第三个矩阵C:\n"); //三行三列
for (i = 0; i < ROW; i++)//从arr[0][0] 开始存入数据
{
for (j = 0; j < COL; j++)
{
int sum = 0; //临时存储
for (m = 0; m < MID; m++)
{
sum = sum + arr1[i][m] * arr2[m][j]; //arr1[0][m] * arr2[m][0];
}
arr3[i][j] = sum; //计算第一个值存入矩阵,然后重新循环变成arr3[0][1]
}
}
for (i = 0; i < ROW; i++) //输出矩阵
{
for (j = 0; j < COL; j++)
{
printf("%3d ", arr3[i][j]);//输出每一个数值
}
printf("\n");
}
return 0;
}