2012-02-26 4 views
7

私は長い処理の結果があります。私はそれをHashMapに直接渡したくないし、さらに計算をしたい。私はそれを保存し、毎回再利用したい。値のアイテムの配列でHashMapを初期化しますか?

私の配列は次のようになります。

{0=0, 1=15, 2=70, 3=90, 4=90, 5=71, 6=11, 7=1, 8=61, 9=99, 10=100, 11=100, 12=100, 13=66, 14=29, 15=98, 17=100, 16=100, 19=100, 18=100, 21=62, 20=90, 23=100, 22=100, 25=100, 24=100, 27=91, 26=100, 29=100, 28=68, 31=100, 30=100, 34=83, 35=55, 32=100, 33=100, 38=100, 39=100, 36=100, 37=100, 42=10, 43=90, 40=99, 41=33, 46=99, 47=40, 44=100, 45=100, 48=2} 

は、これらの値を渡すことによって、新しいHashMapを初期化する方法はありますか?たぶん、単純な配列を初期化するようなもの:値でHashMapを初期化する

float[] list={1,2,3}; 
+1

キーは本当に連続した整数ですか? –

+0

配列の値の型は何ですか?マップのキーと値のタイプはどうすればよいですか? –

+0

@BorisStrandjevはい、以前のHashMapの内容です。 – Andrew

答えて

8

問題については、あなたが私たちのインフロントを入れて最善の解決策は次のようになります。

int [] map = 
    {0, 15, 70, 90, 90, 71, 11, 1, 61, 99, 100, 100, 100, 66, 29, 98, 100, 100, 
    100, 100, 90, 62, 100, 100, 100, 100, 100, 91, 68, 100, 100, 100, 100, 100, 
    83, 55, 100, 100, 100, 100, 99, 33, 10, 90, 100, 100, 99, 40, 2}; 

これは、すべての後に、マップのようなものです - インデックスを対応する値にマップします。しかし、あなたのキーがそれほど具体的でない場合は、次のようなことができます:

int [][] initializer = 
    {{0, 0}, {1, 15}, {2, 70}, {3, 90}, {4, 90}, {5, 71}, {6, 11}, {7, 1}, {8, 61}, 
    {9, 99}, {10, 100}, {11, 100}, {12, 100}, {13, 66}, {14, 29}, {15, 98}, 
    {17, 100}, {16, 100}, {19, 100}, {18, 100}, {21, 62}, {20, 90}, {23, 100}, 
    {22, 100}, {25, 100}, {24, 100}, {27, 91}, {26, 100}, {29, 100}, {28, 68}, 
    {31, 100}, {30, 100}, {34, 83}, {35, 55}, {32, 100}, {33, 100}, {38, 100}, 
    {39, 100}, {36, 100}, {37, 100}, {42, 10}, {43, 90}, {40, 99}, {41, 33}, 
    {46, 99}, {47, 40}, {44, 100}, {45, 100}, {48, 2}}; 
Map<Integer, Integer> myMap = new HashMap<Integer, Integer>(); 
for (int i = 0; i < initializer.length; i++) { 
    myMap.put(initializer[i][0], initializer[i][1]); 
} 
2

唯一の方法は、あなたがオブジェクトを作成した後put()方法を複数回使用することです。これは、HashMapが、マップ内のオブジェクトを適切に順序付けして保証されたパフォーマンスを達成するために、ハッシングメカニズムを実行する必要があるからです。

1

私が知る限り、配列として簡単にハッシュマップをインスタンス化することはできません。あなたは何ができるか

、utitlityメソッドを記述し、マップをインスタンス化するためにそれを使用です:

Map<Integer, Integer> createMap(Integer[] array) { 
    Map<Integer, Integer> map = new HashMap<Integer, Integer>(); 
    for(int i = 0; i < array.length; i++) { 
     map.put(i, array[i]); 
    } 
    return map; 
} 
2

あなたの質問は非常に紛らわしいです。マップの内容を別のマップにコピーするには、putAllメソッドを使用します。

Map<Integer, Integer> newMap = new HashMap<Integer, Integer>(); 
newMap.putAll(oldMap); 

または直接コピーコンストラクタ:

Map<Integer, Integer> newMap = new HashMap<Integer, Integer>(oldMap); 
+0

またはコンストラクタを使用してください: 'HashMap(Map <?extends K、?extends V> m)' :) –

+0

もちろん。私は私の答えを編集します:-) –

+0

oldMapはどのデータ型ですか? –