題目描述
如果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 matric(int [][] a,int [][]b,int a_row,int b_col,int y ){
int[][] c = new int [a_row][b_col];
for(int i =0 ; i<a_row;i++){
for (int j=0;j<b_col;j++){
int sum = 0;
for(int k = 0;k<y;k++){
sum = sum+a[i][k]*b[k][j];
}
c[i][j] = sum;
}
}
for(int i =0;i<a_row;i++){
for(int j = 0;j<b_col-1;j++){
System.out.print(c[i][j]+" ");
}
System.out.println(c[i][b_col-1]);
}
}
public static void main(String[] args){
Scanner sc= new Scanner(System.in);
while(sc.hasNext()){
int matric1_row = sc.nextInt();
int y = sc.nextInt();
int matric2_col = sc.nextInt();
int[][] matric1 = new int[matric1_row][y];
int[][] matric2 = new int[y][matric2_col];
for (int i =0 ;i<matric1_row;i++){
for (int j=0;j< y;j++)
{
matric1[i][j]=sc.nextInt();
}
}
for (int j=0;j<y;j++ ){
for(int k = 0;k <matric2_col;k++){
matric2[j][k]=sc.nextInt();
}
}
matric(matric1,matric2,matric1_row,matric2_col,y);
// System.out.print("\n");
}
}
}