2013-11-21 53 views
1

在完成包含两个二维数组并将它们相乘的程序时,遇到了一些麻烦。现在我能够构建这些具有设定长度的数组,然后使用数字生成器来创建每个数组。至于第三个数组,我能够建立数组的长度,但是当把三个数组放入一个方法时,我仍然有超出界限的问题。乘以多维数组

for(int k = 0; k < totalMatrix.length; k++) 

矩阵:

public class arrayTest1{ 
    public static void main (String [] args){ 
    int matrix1[][] = new int [5][2]; 

    for (int i = 0; i < matrix1.length; i++) 
     for (int j = 0; j < matrix1[i].length; j++) 
     matrix1[i][j] = (int)(Math.random() * 1000); 

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

    int matrix2[][] = new int [2][5]; 

    for (int i = 0; i < matrix2.length; i++) 
     for (int j = 0; j < matrix2[i].length; j++) 
     matrix2[i][j] = (int)(Math.random() * 1000); 

     System.out.println("The array 2 is: "); 
    for (int i = 0; i < matrix2.length; i++){ 
     for (int j = 0; j < matrix2[i].length; j++){ 
     System.out.print(matrix2[i][j]+" "); 
     } 
     System.out.println(); 
    } 

    int matrixSum[][] = new int [matrix1.length][matrix2[0].length]; 

    matrixMulti(matrix1,matrix2,matrixSum); 

    System.out.println("The array mutliplied is: "); 
    for (int i = 0; i < matrixSum.length; i++){ 
     for (int j = 0; j < matrixSum[i].length; j++){ 
     System.out.print(matrixSum[i][j]+" "); 
     } 
     System.out.println(); 
    } 
    } 

    public static void matrixMutli(int [][] m1, int [][] m2,int [][] totalMatrix){ 


    for(int i = 0; i < m1.length; i++) 
     for(int j = 0; j < m2[0].length; j++) 
     for(int k = 0; k < totalMatrix.length; k++) 
     totalMatrix [i][j] += m1[i][k] * m2[k][j]; 
    } 
} 
+0

究竟是什么方法?你能提供代码吗? – IHazABone

+0

我的不好。我基于我正在开发的一个附加程序的代码。我重命名了引入matrixMulti数组的方法。 – user3015726

回答

0

ArrayIndexOutOfBounds由您k变量从0到5,它需要从0到去2.问题是因为该行的事实引起的totalMatrix被初始化int matrixSum[][] = new int [matrix1.length][matrix2[0].length];matrix1.length是5。所以totalMatrix.length是5

要纠正这一点,你需要确保k是由matrix1[i].lengthmatrix2.length限制。这两个值需要相同,您可以选择是否为k的界限。

所以这是代码:

for(int i = 0; i < m1.length; i++) 
    for(int j = 0; j < m2[0].length; j++) 
    for(int k = 0; k < m2.length; k++) 
     totalMatrix [i][j] += m1[i][k] * m2[k][j]; 

也可以考虑补充说,检查是否m1[i].length == m2.length并引发IllegalArgumentException如果没有代码。如果您仍然遇到麻烦,请查看matrix multiplication