Как сделать значение карты пустым при сравнении его со значениями другой карты? - PullRequest
0 голосов
/ 28 февраля 2019

Предположим, у меня было две карты region1, region2, и обе они объявлены как

LinkedHashMap<String, List<String>> region1 = new LinkedHashMap<>();

LinkedHashMap<String, List<String>> region2 = new LinkedHashMap<>();

region1 содержит следующие значения:

region1 : {R1 = [A, B, C, D]}

region2 содержит следующие значения:

region2 : {R2 = [G, A, D, B]}

Учитывая значения region1 в качестве базовых значений, переберите значения region2, и неповторяющиеся значения должны быть помещены в другую карту с ключом region2 и неповторяющимся значением region2.

Таким образом, карта region3 содержит

region3 : {R2 = [G]}

И мы повторяем region3 по другой карте, сравнивая совпадающие значения

map1 : {1 = [G, C]}

Поскольку в значении есть совпадение, нам нужно добавить пробелв совпавшем значении.

Таким образом, map1 содержит значения

map1 : {1=[  , C]}

Ответы [ 2 ]

0 голосов
/ 28 февраля 2019

Без использования потоков вы можете решить это следующим образом:

public static void main(String[] args) {

    // setup the input and output maps
    LinkedHashMap<String, List<String>> region1 = new LinkedHashMap<>();
    LinkedHashMap<String, List<String>> region2 = new LinkedHashMap<>();
    LinkedHashMap<String, List<String>> region3 = new LinkedHashMap<>();
    region1.put("R1", asList("A", "B", "C", "D"));
    region2.put("R2", asList("G", "A", "D", "B"));

    // for each key in region2
    for(String key : region2.keySet()) {

        // make a copy of the values for that key
        List<String> values = new ArrayList<>(region2.get(key));

        // remove all the duplicates from each of the lists in region1
        for (List<String> baseValues : region1.values()) {
            values.removeAll(baseValues);
        }

        // if there are any remaining list values
        if (values.size() > 0) {
            // put them into region3
            region3.put(key, values);
        }
    }

    System.out.println(region3);
}
0 голосов
/ 28 февраля 2019

Редактировать: оптимизировано.
Stream только.Исходные объекты не модифицируются.
Однако, немного длиннее.

final Map<String, List<String>> region1 = new LinkedHashMap<>();
region1.put("R1", new ArrayList<>(Arrays.asList("A", "B", "C", "D")));

final Map<String, List<String>> region2 = new LinkedHashMap<>();
region2.put("R2", new ArrayList<>(Arrays.asList("A", "G", "C", "B")));
region2.put("R3", new ArrayList<>(Arrays.asList("A", "G", "C", "B")));

final Stream<Entry<String, List<String>>> entries =
        region1.values()
               .stream()
               .flatMap(values ->
                       region2.entrySet()
                              .stream()
                              .map(e -> {
                                  final List<String> value =
                                          e.getValue()
                                           .stream()
                                           .filter(v -> !values.contains(v))
                                           .collect(toList());
                                  return new SimpleEntry<>(e.getKey(), value);
                              })
               );

final Map<String, List<String>> result = entries.collect(toMap(Entry::getKey, Entry::getValue));

И именно поэтому мне нравятся Stream с.С выводом типа (Java 10+) это еще чище.

...