从2D数组创建距离矩阵

时间:2014-07-28 12:10:32

标签: java arrays matrix distance subtraction

我有一个2D数组(带有x行和y列的inputMatrix),需要相互减去所有向量(行)。

Here's the input:

1,5
3,7
2,3
6,5
4,7

输出(距离矩阵)应如下所示:

subtraction[0][0] = {0,0} // first row - first row
subtraction[0][1] = {-2,-2} // first row - 2nd row -> {1,5}-{3,7}=-2,2
subtraction[0][2] = {-1,2} // first row - 3rd row 
...
subtraction[4][2] = {2,4}
subtraction[4][3] = {-2,2}
subtraction[4][4] = {0,0}

但是我在存储值方面存在问题,因为在“col for-loop”中正在覆盖减法[row] [col]值。另外注意,每个减法索引都是另一个数组的输出。

for(int row = 0; row < inputMatrix.length; row++){
            for(int col = 0; col < inputMatrix[0].length; col++){
                subtraction[row][col] = inputMatrix[0][row] - inputMatrix[row][col];
                System.out.print(subtraction[row][col] + " ");
            }
        System.out.print("\n");
    }

2 个答案:

答案 0 :(得分:1)

根据您对输出的描述,您需要一个三维数组来存储输出,因为对于每对输入行,您将生成一个输出行。

for(int row1 = 0; row1 < inputMatrix.length; row1++){
   for(int row2 = 0; row2 < inputMatrix.length; row2++){
        for(int col = 0; col < inputMatrix[0].length; col++){
            subtraction[row1][row2][col] = inputMatrix[row1][col] - inputMatrix[row2][col];
        }
    }
}

如果必须具有二维输出,则可以展平输出:

int outputRow = 0;
for(int row1 = 0; row1 < inputMatrix.length; row1++){
   for(int row2 = 0; row2 < inputMatrix.length; row2++){
        for(int col = 0; col < inputMatrix[0].length; col++){
            subtraction[outputRow][col] = inputMatrix[row1][col] - inputMatrix[row2][col];
        }
        outputRow++;
    }
}

答案 1 :(得分:0)

subtraction[row][col] = inputMatrix[0][row] - inputMatrix[**row**][**col**];

你在这里混淆了你的指数。