Умножение матриц через функцию на Java — пример с методом

Чтобы умножение матриц вообще было возможно, число столбцов первой матрицы должно совпадать с числом строк второй матрицы. В нашем примере это означает:

c1 = r2

Размер итоговой матрицы-произведения будет r1 x c2:

product[r1][c2]

В этом примере мы вынесем умножение матриц в отдельный метод, чтобы основная программа стала чище, а саму логику умножения можно было повторно использовать.

Пример: программа для умножения двух матриц через функцию

public class MultiplyMatrices {

    public static void main(String[] args) {
        int r1 = 2, c1 = 3;
        int r2 = 3, c2 = 2;
        int[][] firstMatrix = { {3, -2, 5}, {3, 0, 4} };
        int[][] secondMatrix = { {2, 3}, {-9, 0}, {0, 4} };

        // Mutliplying Two matrices
        int[][] product = multiplyMatrices(firstMatrix, secondMatrix, r1, c1, c2);

        // Displaying the result
        displayProduct(product);
    }

    public static int[][] multiplyMatrices(int[][] firstMatrix, int[][] secondMatrix, int r1, int c1, int c2) {
        int[][] product = new int[r1][c2];
        for(int i = 0; i < r1; i++) {
            for (int j = 0; j < c2; j++) {
                for (int k = 0; k < c1; k++) {
                    product[i][j] += firstMatrix[i][k] * secondMatrix[k][j];
                }
            }
        }

        return product;
    }

    public static void displayProduct(int[][] product) {
        System.out.println("Product of two matrices is: ");
        for(int[] row : product) {
            for (int column : row) {
                System.out.print(column + "    ");
            }
            System.out.println();
        }
    }
}

Вывод:

Product of two matrices is:
24    29
6    25

В программе выше определены две функции:

  • multiplyMatrices() — перемножает две переданные матрицы и возвращает результат-произведение.

  • displayProduct() — выводит итоговую матрицу-произведение на экран.

Само умножение происходит по такой формуле:

|-    (a11 x b11) + (a12 x b21) + (a13 x b31)    (a11 x b12) + (a12 x b22) + (a13 x b32)    -|
|_    (a21 x b11) + (a22 x b21) + (a23 x b31)    (a21 x b12) + (a22 x b22) + (a23 x b32)    _|

В нашем примере подстановка чисел даёт следующий результат:

|-    (3 x 2) + (-2 x -9) + (5 x 0) = 24    (3 x 3) + (-2 x 0) + (5 x 4) = 29    -|
|_    (3 x 2) + ( 0 x -9) + (4 x 0) = 6    (3 x 3) + ( 0 x 0) + (4 x 4) = 25    _|

Совет

Вынося умножение в отдельный метод, ту же функцию можно переиспользовать для любых других матриц нужных размеров — не придётся переписывать тройной цикл каждый раз заново.