import java.util.Scanner;
public class Test19 {
/*
题目描述
如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的
矩阵C。这个矩阵的每个元素是由下面的公式决定的:
原型:
voidmatrix_multiply(int *m1,int *m2,int *r, int x, int y, int z);
输入参数:
int *m1:x行y列的矩阵(array1[x][y])
int *m2:y行z列的矩阵(array2[y][z])
int x:矩阵m1的行数
int y:矩阵m1的列数/矩阵m2的行数
int z:矩阵m2的列数
输出参数:
int *r:矩阵m1, m2相乘的结果(array3[x][z])
返回值:
void
输入描述:
输入说明: 1、第一个矩阵的行数 2、第一个矩阵的列数和第二个矩阵的行数 3、第二个
矩阵的列数 4、第一个矩阵的值 5、第二个矩阵的值
输出描述:
输出两个矩阵相乘的结果
输入例子:
2
2
2
3 8
8 0
9 0
18 9
输出例子:
171 72
72 0
*/
public static void main(String[] args) {
Scanner scn=new Scanner(System.in);
while(scn.hasNext()){
int x=scn.nextInt();
int y=scn.nextInt();
int z=scn.nextInt();
int[][] a=new int[x][y];
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
a[i][j]=scn.nextInt();
}
}
int[][] b=new int[y][z];
for (int i = 0; i < y; i++) {
for (int j = 0; j < z; j++) {
b[i][j]=scn.nextInt();
}
}
matrix_multiply(a, b, x, y, z);
}
}
public static void matrix_multiply(int[][] m1,int[][] m2,
int x,int y,int z){
int[][] r=new int[x][z];
for (int i = 0; i < x; i++) {
for (int j = 0; j < z; j++) {
r[i][j]=0;
for (int k = 0; k < y; k++) {
r[i][j]+=m1[i][k]*m2[k][j];
}
if(j==z-1){
System.out.println(r[i][j]);
}else{
System.out.print(r[i][j]+" ");
}
}
//System.out.println();
}
}
}