解题思路:利用通用的矩阵乘法公式求解,如果一个一个元素求,本题中因为乘法结果为2*2可以,但是如果是10*10,甚至更多会累死的!
注意事项:本题是多组输入,但是不知道如何多组输入二维数组,因此把输入的第一个二维数组的首行输入任务放在循环体内,以达到多组输入目的!
参考代码:
#include<stdio.h>
int main()
{
int m,n;
int i,j;
int k;
int a1[2][3],a2[3][2];
int a3[2][2];
m=2;n=3;
while(scanf("%d%d%d",&a1[0][0],&a1[0][1],&a1[0][2])!=EOF)//将第一个二维数组首行输入放入循环体
{
for(j=0;j<n;j++) //输入第一个二维数组剩余部分
scanf("%d",&a1[1][j]);
for(i=0;i<n;i++) //输入第二个二维数组
for(j=0;j<m;j++)
scanf("%d",&a2[i][j]);
for(i=0;i<m;i++) //求出乘积数组中的每一个元素
{
for(j=0;j<m;j++)
{
a3[i][j]=0; //初始化乘积数组
for(k=0;k<n;k++)
a3[i][j]+=a1[i][k]*a2[k][j]; //利用矩阵乘法公式求每一个元素放入乘积数组中
}
}
for(i=0;i<m;i++) //按格式输出乘积数组
{
for(j=0;j<m;j++)
{
printf("%d ",a3[i][j]);
}
printf("\n");
}
}
return 0;
}
0.0分
1 人评分
兰顿蚂蚁 (C++代码)浏览:1091 |
Wu-求圆的面积 (C++代码)浏览:1885 |
WU-C语言程序设计教程(第三版)课后习题12.1 (C++代码)浏览:919 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:468 |
1009题解浏览:736 |
1908题解浏览:633 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:398 |
杨辉三角 (C语言代码)浏览:484 |
Hello, world! (C语言代码)浏览:824 |
用筛法求之N内的素数。 (C语言代码)浏览:529 |