キーが文字列で、値がコンマで区切られた値のリストであるマップがあります。
キーと値のペアの順序を逆にして、キーが値になり、値がキーになるように新しいマップに割り当てるにはどうすればよいですか?
それで :
key value key1 value1,value2,value3 key2 value1,value4,value5 key3 value4,value2,value1
になります:
key value value1 key1,key2,key3 value2 key1,key3 value3 key1 value4 key2,key3 value5 key2
考えられる解決策は、各値を反復処理してから、すべてのキーを反復処理して、対応する同じ値を検索することです。見つかった場合は、この新しいキーと値のペアを新しいマップに追加します。これは非効率に思えますか?
解決策(受け入れられた回答を使用して実装):
import java.util.HashMap;
import java.util.Map;
public class MapTransformer {
public static void main(String args[]) {
Map<String, String> m1 = new HashMap<String, String>();
m1.put("key1", "value1,value2");
m1.put("key2", "value5");
m1.put("key3", "value4,value2,value1");
Map<String, String> inverseMap = new HashMap<String, String>();
for (Map.Entry<String, String> entry : m1.entrySet()) {
for (String value : entry.getValue().split(",")) {
if (inverseMap.containsKey(value))
inverseMap.put(value, inverseMap.get(value) + "," + entry.getKey());
else
inverseMap.put(value, entry.getKey());
}
}
for (Map.Entry<String, String> entry : inverseMap.entrySet()) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key+" "+value);
}
}
}