-3

と呼ばれる3D配列がありeMます:

double[][][] eM = new double[4][4][4];

を に変換するヘルパー メソッドもありintますchar

public static char intToChar(int i) {
    switch (i) {
    case 0:
        return 'A';
    case 1:
        return 'B';
    case 2:
        return 'C';
    default:
        return 'D';
    }
}

4 つの整数変数があります。

int A = 108;
int B = 299;
int C = 302;
int D = 411;

さて、ここがトリッキーな部分です。3D 配列 eM の各インデックスを調べて、そのインデックス値を乗算したいと考えています。だから [0][0][0] = 1*1*1 = 1; [0][0][1] = 1*1*2 = 2; ...; [3][3][3] = 4*4*4 = 64

for (int i=0; i<4; i++){
    for (int j=0; j<4; j++){
        for (int k=0; k<4; k++){
            char I = intToChar(i);
            char J = intToChar(j);
            char K = intToChar(k);
            // Not sure what to do here
        }
    }
}

どうやってやるの?

4

4 に答える 4

2

A...D をインデックスで参照できるようにする必要があるため、配列でインデックスを付ける必要があります。

int[] d = {A, B, C, D};

forループの前に行きます。次に、for ループは簡単です。

eM[i][j][k] = d[i]*d[j]*d[k];

これにより、各値(i,j,k)が対応する A...D 被乗数に設定されます。

于 2013-04-18T07:16:23.140 に答える
0

最終バージョン。-ea vm オプションを指定して実行し、アサートが機能していることを示します。

 import java.util.HashMap;


public class mult {

    /**
     * @param args
     */
    public static char intToChar(int i) {
        switch (i) {
        case 0:
            return 'A';
        case 1:
            return 'B';
        case 2:
            return 'C';
        default:
            return 'D';
        }
    }
    public static void main(String[] args) {
        HashMap<Character, Integer> lookup = new HashMap<Character, Integer>();
        lookup.put('A', 108);
        lookup.put('B', 299);
        lookup.put('C', 302);
        lookup.put('D', 411);
        // TODO Auto-generated method stub
        Integer[][][] eM=new Integer[4][4][4];
        for (int i=0; i<4; i++){
            for (int j=0; j<4; j++){
                for (int k=0; k<4; k++){
                  eM[i][j][k] = (lookup.get(intToChar(i))) * 
                          (lookup.get(intToChar(j))) *
                          (lookup.get(intToChar(k)));
                }
            }

    }

assert(eM[0][0][0] == 108*108*108);
assert(eM[0][0][1] == 108*108*299);
assert(eM[3][3][3] == 411*411*411);
}
}
于 2013-04-18T07:31:32.740 に答える
0

したがって、インデックスに対応する char に対応する整数の値を取得する必要があります。intToChar ステップを削除して、必要なインデックスの整数値を直接取得できると思います。

public static int getIntValue(int i) {
    switch (i) {
    case 0:
        return 108;
    case 1:
        return 299;
    case 2:
        return 302;
    default:
        return 411;
    }
}



for (int i=0; i<4; i++){
        for (int j=0; j<4; j++){
            for (int k=0; k<4; k++){
                eM[i][j][k]= getIntValue(i) * getIntValue(j) * getIntValue(k);

            }
        }
    }
于 2013-04-18T07:17:24.953 に答える