今天开始学Java 如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C

题目描述

  • 如果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、第二个矩阵的值

输出描述:

 
 

输出两个矩阵相乘的结果

示例1

输入

2
2
2
3 8
8 0
9 0
18 9

输出

171 72
72 0

public class Main{
    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");
    }
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值