每行和每列的最小元素

时间:2015-11-29 17:43:36

标签: matrix row each minimum

这可能听起来很愚蠢,但我无法让它发挥作用。 在读取矩阵有多少行和多少列之后,我试图在每一行上显示最小元素,然后在每列上显示最小元素。

我的代码看起来像这样,但有时它会抛出一个IndexOutOfBoundsException,有时它只显示列的最小值,仅用于行。

有效的行代码是

public static void minRand(int[][] n) {

    int[] result = new int[n.length];
    int min = 0;


    for (int i = 0; i < n.length; i++) {
        for (int j = 0; j < n[0].length; j++) {
            if (n[i][j] < n[i][min]) {
                min = j;
            }
            result[i] = n[i][min];
        }
        System.out.println("Minimum on line " + i + " is " + result[i]);
    }

}

列的代码不起作用

public static void minCol(int[][] n) {

    int[] result = new int[n[0].length];
    int min = 0;

        for (int i = 0; i < n.length; ++i) {
            min = Integer.MAX_VALUE;
            for (int j = 1; j < n[i].length; ++j)
                if (n[j][i] < min)
                    min = n[j][i];
            System.out.println("Minimum on column no " + i + " is " + min);
        }

}

如果我给它3行和4列,控制台会显示:

    Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 3
        at Principal.minCol(Principal.java:103)
        at Principal.afisareMeniu(Principal.java:196)
        at Principal.main(Principal.java:13)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:497)
        at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)

Minimum on line 0 este 0
Minimum on line 1 este 0
Minimum on line 2 este 0

它是0因为我没有初始化矩阵,但每行的最小值都有效。

同时。如果我给它一个方阵,那么行和列的最小值都可以工作。 我究竟做错了什么?

1 个答案:

答案 0 :(得分:0)

// Minimum in Column
 public static void colMin(double[][] n){
    double[] result = new double[n.length];
    double min = 0;
    System.out.println("Column min values: ");
    for (int i = 0; i < n.length; ++i) {
        min = Integer.MAX_VALUE;
        for (int j = 1; j < n[i].length; ++j)
            if (n[j][i] < min){
                min = n[j][i];
                result[i] = min;
            }

        System.out.printf("%.2f ", result[i]);
        System.out.println();
    }

}

如上所示,只需将计算出的min分配给result [i]。 和显示。

干杯。