Bootstrap

华为 HJ69矩阵乘法

*******后序更新关于scanf函数的用法
题目描述
如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C。

输入描述:
输入包含多组数据,每组数据包含:

第一行包含一个正整数x,代表第一个矩阵的行数

第二行包含一个正整数y,代表第一个矩阵的列数和第二个矩阵的行数

第三行包含一个正整数z,代表第二个矩阵的列数

之后x行,每行y个整数,代表第一个矩阵的值

之后y行,每行z个整数,代表第二个矩阵的值

输出描述:
对于每组输入数据,输出x行,每行z个整数,代表两个矩阵相乘的结果
示例1
输入
复制
2
3
2
1 2 3
3 2 1
1 2
2 1
3 3
输出
复制
14 13
10 11
#include <stdio.h>

int main(void)
{
int x,y,z,i,j,k;
int mar1[100][100];
int mar2[100][100];
int mar3[100][100];

while(~scanf("%d\n%d\n%d\n",&x,&y,&z))
{

for(i=0;i<x;i++)
{
    for(j=0;j<y;j++)
    {
        mar1[i][j]=0;
        scanf("%d",&mar1[i][j]);
    }
}

for(i=0;i<y;i++)
{
    for(j=0;j<z;j++)
    {
        mar2[i][j]=0;
        scanf("%d",&mar2[i][j]);
    }
}

for(i=0;i<x;i++)
{
    for(j=0;j<z;j++)
    {
        mar3[i][j] = 0;
        for(k=0;k<y;k++)
        {
            mar3[i][j] += (mar1[i][k] * mar2[k][j]);
        }
    }
}

for(i=0;i<x;i++)
{
    for(j=0;j<z;j++)
    {
        printf("%d ",mar3[i][j]);
    }
    printf("\n");
}
}
return 0;

}

;