I have a Map<B, List<A>>
. I want to filter out some A based on some predicate which relies on the key of the map entry of type B. For example here is my data structure:
List<Integer> list1 = Arrays.asList(5,2,3,4);
List<Integer> list2 = Arrays.asList(5,6,7,8);
List<Integer> list3 = Arrays.asList(9,10,11,12,13);
List<Integer> list4 = Arrays.asList(11,23,112);
Map<Long, List<Integer>> map = new HashMap<>();
map.putIfAbsent(2L, list1);
map.putIfAbsent(3L, list2);
map.putIfAbsent(4L, list3);
map.putIfAbsent(5L, list4);
Now I want to iterate through the entrySet of the map and make a new map having list containing the elements which is a multiple of the key of that entry. i.e. The output should look like this:
2L --> List of (2, 4)
3L --> List of (6)
4L --> List of (12)
5L --> empty List
The filtering predicate uses the map entry key value to test the list elements. How can I achieve this without modifying the original map ?
Here's one way to solve the problem, by streaming the entries in the original map, and creating a new map with the keys and filtered lists:
Map<Long, List<Integer>> newMap = map.entrySet().stream()
.collect(Collectors.toMap(Map.Entry::getKey, entry -> entry.getValue().stream()
.filter(value -> value % entry.getKey() == 0)
.collect(Collectors.toList())));