7-2 两个矩阵之积
输入整数m、p、n,再输入一个m行p列的整数矩阵A和一个p行n列的整数矩阵B,求两个矩阵的乘积AB
输入格式:
测试数据有多组,处理到文件尾。每组测试数据的第一行输入m、p、n(1<m,p,n<10),接下来分别输入A矩阵和B矩阵。
输出格式:
对于每组测试,输出m行,每行n个整数,表示AB的结果,每行中每两个数据之间留一个空格。
输入样例:
4 3 2
5 2 4
3 8 2
6 0 4
0 1 6
2 4
1 3
3 2
2 2 3
1 2
3 4
5 6 7
7 8 9
输出样例:
24 34
20 40
24 32
19 15
19 22 25
43 50 57
#include<stdio.h>
int main(){
int m,n,p,i,j,k,sum;
int a[100][100];
int b[100][100];
int c[100][100]={0};
while(scanf("%d %d %d",&m,&p,&n)!=EOF){
for(i=0;i<m;i++){
for(j=0;j<p;j++){
scanf("%d",&a[i][j]);
}
}
for(j=0;j<p;j++){
for(k=0;k<n;k++){
scanf("%d",&b[j][k]);
}
}
for(i=0;i<m;i++){
for(j=0;j<n;j++){
c[i][j]=0;
for(k=0;k<p;k++){
c[i][j]+=a[i][k]*b[k][j];
}
}
}
for(i=0;i<m;i++){
for(j=0;j<n;j++){
if(j<n-1)
printf("%d ",c[i][j]);
if(j==n-1){
printf("%d\n",c[i][j]);
}
}
//printf("\n");
}
}
return 0;
}