1

だから私はJavaで数値メソッドを始めたばかりです。

// I have a matrix class that has get, set methods for creating matrices; have used those in the method below.
// The method below computes a Matrix and prints as well returns it.

public Matrix computeA(){

    int nrows = A.getNumRows();
    int ncols = A.getNumCols();

    for(int i = 0; i < nrows; i++){
        double sum = 0.0;
        for (int j = 0; i< ncols; j++){
                         if (i!=j){
             A.setElement(i,j, aijCalc(i,j) );} // aijCalc is numeric method; setElement has parameters (i, j, value)
        }
    A.print();
    return A;
}

さて、これが私が行う方法を理解していないことです:i = jである対角線、行列エントリは1-(その行のすべてのaijエントリ(i!= jの場合)の合計)。上記の方法でこれをコーディングするにはどうすればよいですか?

私の現在の出力(四捨五入なしは次のようになります):

0.0 0.026055555555555554 0.0248125 0.050694444444444445 0.05872222222222222 0.030208333333333334

-0.0053750000000000004 0.0 0.00792361111111111 0.01813194444444444 0.02361111111111111 0.009874999999999998

-0.0013854166666666667 -0.005291666666666666 0.0 0.008680555555555556 0.009041666666666667 0.0

0.0 0.009041666666666667 0.008680555555555556 0.0 -0.005291666666666666 -0.0013854166666666667

0.009874999999999998 0.02361111111111111 0.01813194444444444 0.00792361111111111 0.0 -0.0053750000000000004

0.030208333333333334 0.05872222222222222 0.050694444444444445 0.0248125 0.026055555555555554 0.0

(i = jの場合は0があります)

そしてそれはこのように見えるはずです:

0.810 0.026 0.025 0.051 0.059 0.030

-‐0.005 0.946 0.008 0.018 0.024 0.010

-‐0.001 -‐0.005 0.989 0.009 0.009 0.000

0.000 0.009 0.009 0.989 -‐0.005 -‐0.001

0.010 0.024 0.018 0.008 0.946 -‐0.005

0.030 0.059 0.051 0.025 0.026 0.810

ありがとう!

4

1 に答える 1

3

それらの余分なゼロは事実上「嘘」です。

提案:数値を現実的な精度(たとえば、小数点以下4桁または5桁)にフォーマットするだけです。

例:

System.out.println (String.format ("%11.2f", x);

http://docs.oracle.com/javase/1.5.0/docs/api/java/util/Formatter.html

PS:

C#やC ++を含む、他のほぼすべての言語の浮動小数点「printf」についてもまったく同じことが言えます。

于 2012-12-07T04:56:14.850 に答える