Java两个阵列的产品



我想解决我的作业问题。我必须使用我创建的Java中的方法将数组自行乘以。但是,我的方法不起作用,我不知道为什么。

public static void initialiser(int mat[][]) {
    int i,j;
    for (i = 0; i < mat.length; i++) {
        for(j = 0; j < mat[0].length; j++) {
            mat[i][j] = 0;
        }
    }
}
public static int[][] produit(int mat1[][], int mat2[][]) {
    int i,j,k;
    int [][] matProduit = new int[mat1.length][mat2[0].length];
    for (i = 0; i < mat1.length; i++) {
        for(j = 0; j < mat2[0].length; j++) {
            initialiser(matProduit);
            for (k = 0; k < mat2.length; k++) {
                matProduit[i][j] =  mat1[i][k] * mat2[k][j];
            }
        }
    }
    return matProduit;
}

这是我应该得到的结果:

0   1   0   0   0   0
0   0   1   0   0   1
0   0   0   0   1   1
0   0   1   0   1   0
0   0   0   0   0   0
0   0   0   0   0   0

这是我得到的结果:

0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0
0 0 0 0 0 0

,Assylias在评论中指出,您在每次迭代时都调用initialiser(matProduit),从而将矩阵重置为零。

我建议您尝试解决此类问题的调试模式。这是您日常编码的最佳工具。

请在另一个问题上找到自己的答案,对调试,如何做,激活并至少正确使用它。

最新更新