Массив исключений за пределами

Мой код должен умножить каждую строку массива на каждый столбец следующего. Пользователь вводит высоту и ширину, и программа случайным образом генерирует значения массива. Это не дает никаких ошибок, если массивы равны, например (3x3)(3x3) или даже если вы делаете (3x2)(2x3). однако, если вы введете что-то вроде (3x3)(3x2), это даст исключение вне границ.

public class Multiply {

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);

        int width = -1;
        int height = 0;
        int width2 = 0;
        int height2 = 0;

        while (width != height2) {

            while (height <= 0) {
                System.out.print("Enter a height for array1: ");
                height = checkInt(scan);
            }

            while (width <= 0) {
                System.out.print("Enter a width for array1: ");
                width = checkInt(scan);
            }

            while (height2 <= 0) {
                System.out.print("Enter a height for array2: ");
                height2 = checkInt(scan);
            }

            while (width2 <= 0) {
                System.out.print("Enter a width for array2: ");
                width2 = checkInt(scan);
            }

            if (width != height2) {
                System.out
                        .println("Error! Dimensions of matrices not compatible. Try again.");
                width = -1;
                height = 0;
                width2 = 0;
                height2 = 0;
            }
        }

        int array1[][] = randomMatrix(height, width);
        int array2[][] = randomMatrix(height2, width2);
        int product[][] = matrixMultiply(array1, array2, height, width2);

        printArray(product);

    }// end of main method

    public static int[][] randomMatrix(int height, int width) {
        int array1[][] = new int[height][width];
        for (int i = 0; i < height; i++) {
            for (int j = 0; j < width; j++) {
                array1[i][j] = (int) (-10 + Math.random() * 20);
            }
        }
        return array1;
    }// end of randomMatrix method

    public static int[][] matrixMultiply(int[][] array1, int[][] array2, int height, int width) {
        int[][] product = new int[height][width];
        for (int i = 0; i < array1.length; i++) {
            for (int j = 0; j < array1[i].length; j++) {
                int prod = 0;
                for (int k = 0; k < array2.length; k++) {
                    prod = prod + array1[i][k] * array2[k][j];
                }
                product[i][j] = prod;
            }
        }
        return product;
    }// end of matrixMultiply method

    public static void printArray(int[][] array) {
        System.out.println(" ");
        System.out.println("Row Major Representation:");

        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array[i].length; j++) {
                System.out.print(array[i][j] + " ");
            }
            System.out.println();
        }
        System.out.println(" ");
        System.out.println("Column Major Representation:");

        for (int i = 0; i < array[1].length; i++) {
            for (int j = 0; j < array.length; j++) {
                System.out.print(array[j][i] + " ");
            }

            System.out.println();
        }
    }

    public static int checkInt(Scanner scan) {
        int width = 0;
        if (scan.hasNextInt()) {
            width = scan.nextInt();
            return width;
        } else {
            scan.next();
            return 0;
        }

    }

}// end of public class Multiply

1 ответ

Решение

Значение переменной "j" (строка 82) в ее последней итерации вызывает исключение Out of Bounds. Ошибка возникает для (3x3)(3x2), потому что в последней итерации "j" j равно 2, делая значение больше 1 (самое высокое значение индекса для местоположения j). Добавление некоторой логики для проверки, когда j > самый высокий индекс, предотвратит проблему.

Другие вопросы по тегам