题目描述:
计算两个矩阵的乘积,第一个是23,第二个是32
输入描述:
输入为两个矩阵,其中一个为23的矩阵,另一个为32的矩阵
输出描述:
一个2*2的矩阵(每一个数字后都跟一个空格)
输入
1 2 3
3 4 5
6 7
8 9
10 11
输出
52 58
100 112
通用版
#include <iostream>
#include<cstdio>
using namespace std;
struct Matrix
{
int matrix[3][3];
int row,col;
Matrix(int r,int c):row(r),col(c) {
}
};
Matrix Multiply(Matrix x,Matrix y)
{
Matrix answer(x.row,y.col);
for(int i=0;i<answer.row;i++)
{
for(int j=0;j<answer.col;j++)
{
answer.matrix[i][j]=0;
for(int k=0;k<x.col;k++)
answer.matrix[i][j]+=x.matrix[i][k]*y.matrix[k][j];
}
}
return answer;
}
void PrintMatrix(Matrix x)
{
for(int i=0;i<x.row;i++)
{
for(int j=0;j<x.col;j++)
printf("%d ",x.matrix[i][j]);
printf("\n");
}
}
int main()
{
Matrix x(2,3);
Matrix y(3,2);
for(int i=0;i<x.row;i++)
{
for(int j=0;j<x.col;j++)
scanf("%d",&x.matrix[i][j]);
}
for(int i=0;i<y.row;i++)
{
for(int j=0;j<y.col;j++)
scanf("%d",&y.matrix[i][j]);
}
Matrix answer=Multiply(x,y);
PrintMatrix(answer);
return 0;
}
简洁版
#include <iostream>
using namespace std;
int main()
{
int a[2][3],b[3][2],c[2][2]={0};
for(int i=0;i<2;i++)
{
for(int j=0;j<3;j++)
cin>>a[i][j];
}
for(int i=0;i<3;i++)
{
for(int j=0;j<2;j++)
cin>>b[i][j];
}
for(int i=0;i<2;i++)
{
for(int j=0;j<2;j++)
{
for(int k=0;k<3;k++)
{
c[i][j]+=a[i][k]*b[k][j];
}
}
}
for(int i=0;i<2;i++)
{
for(int j=0;j<2;j++)
{
cout << c[i][j]<< " ";
}
cout<<endl;
}
return 0;
}
本题的核心在于矩阵乘积的三重循环部分,这一点很重要。