4

私は2つ持っていHashMapsます。

HashMap<String, String> hMap=new HashMap<String, String>();
hMap.put("1","one");
hMap.put("2", "two");
hMap.put("3", "three");
hMap.put("4", "four");

HashMap<String, String> hMap2=new HashMap<String, String>();
hMap2.put("one", "");
hMap2.put("two", "");

hMap2 のキーと等しくない hMap を比較したいので、別の hashMap に入れる必要があります。このために、次のようなことを試しました。

HashMap<String, String> hMap3=new HashMap<String, String>();
Set<String> set1=hMap.keySet();
Set<String> set2=hMap2.keySet();

Iterator<String> iter1=set1.iterator();
Iterator<String> iter2=set2.iterator();
String val="";
while(iter1.hasNext()) {

    val=iter1.next();
    System.out.println("key and value in hmap is "+val+" "+hMap.get(val));

    iter2=set2.iterator();

    while(iter2.hasNext()) {
        String val2=iter2.next();
        System.out.println("val2 value is "+val2);

        if(!hMap.get(val).equals(val2)) {
            hMap3.put(val, hMap.get(val));
            System.out.println("value adding");

        }
    }
}
System.out.println("hashmap3 is "+hMap3);

ここで得られる出力は

hashmap3 is {3=three, 2=two, 1=one, 4=four}

私の期待される出力は

hashmap3 is {3=three, 4=four}

私の論理を修正してください。事前に感謝します

4

1 に答える 1

10

あなたは本当にあなたの仕事を複雑にしています。2 番目のマップを反復処理する必要はまったくありません。メソッドを使用Map#containsKey()して、最初のマップの値が 2 番目のマップのキーであるかどうかを確認できます。

したがって、最初のマップを反復処理するだけです。Map.Entryキーと値の両方が必要なため、最初のマップを反復処理できます。を使用してそれを取得しMap#entrySet()ます。

containsKey最初のマップの値が 2 番目のキーであるため、メソッドでメソッドを使用する必要がありますMap.Entry#getValue()

for (Entry<String, String> entry: hMap.entrySet()) {
    // Check if the current value is a key in the 2nd map
    if (!hMap2.containsKey(entry.getValue()) {

        // hMap2 doesn't have the key for this value. Add key-value in new map.
        hMap3.put(entry.getKey(), entry.getValue());
    }
}
于 2013-08-31T08:42:02.917 に答える