我正在写一个程序,通过高斯 - 乔丹方法解决矩阵。除了-1.0/1.0之外,一切都可以使用。打印矩阵时,它应该仍然是-1.0时打印出一个0.0。任何人都可以解释为什么会发生?在下面的例子中,matrix [k] [s]是-1.0,除数是1.0的double值。-1.0/1.0操作返回0?
for(s = 0; s < (n+1); s++){ //Augmented matrix, while s < number of columns
if(divisor == 0.0){ //Not dividing by 0.0
continue;
}
matrix[k][s] = matrix[k][s]/divisor;
if((matrix[k][s] < TOLERANCE) || (matrix[k][s] < -TOLERANCE)){ //To avoid -0.0 values, TOLERANCE == 1e6
matrix[k][s] = 0.0;
}
你确定你不小心打印出来之前,改变矩阵? – aardvarkk