Krz*_*ski 5 arrays java-8 java-stream
假设我有对象列表,每个对象都包含自己的字符串数组。我需要找到与给定数组具有最多重复项的对象。我可以通过使用一些 for 循环、if 和计数器来简单地实现这一点,但我想使用 Java 8 流来做到这一点。我真的希望这是可能的。
@Test
public void test() {
String mainArray[] = {"a", "b", "c"};
List<ElementsList> elems = new ArrayList<>();
ElementsList a = new ElementsList(new String[]{"d", "e", "a"});
ElementsList b = new ElementsList(new String[]{"b", "c", "d"});
elems.add(a);
elems.add(b);
List<ElementsList> result = elems.stream()...;
assertTrue(result.contains(b));
}
private class ElementsList {
private String elements[];
private ElementsList(String elements[]) {
this.elements = elements;
}
public String[] getElements() {
return elements;
}
}
Run Code Online (Sandbox Code Playgroud)
我可以想到这个例如:
List<String> main = Arrays.asList(mainArray);
Stream.of(a, b)
.map(x -> new AbstractMap.SimpleEntry<>(x, new ArrayList<>(new ArrayList<>(Arrays.asList(x.elements)))))
.map(entry -> {
entry.getValue().removeAll(main);
entry.setValue(entry.getValue());
return entry;
})
.sorted(Comparator.comparing(e -> e.getValue().size()))
.map(Entry::getKey)
.forEach(el -> System.out.println(Arrays.toString(el.elements)));
Run Code Online (Sandbox Code Playgroud)
基本上将所有元素放入可变元素中List,然后执行removeAll其中的一个mainArray,并根据剩余元素的大小对结果进行排序。
| 归档时间: |
|
| 查看次数: |
84 次 |
| 最近记录: |