我写了以下代码段来计算每个元素出现的次数。有没有更短的方法可以实现这个功能?
int[] arr = {1, 6, 2, 8, 5, 4, 7, 7, 5, 7};
Arrays.stream(arr)
.collect(ArrayList::new, ArrayList::add, ArrayList::addAll)
.stream()
.collect(Collectors.groupingBy(s -> s))
.forEach((k, v) -> System.out.println(k+" "+v.size()));
我希望您只显示出现超过1次的元素。因此,我尝试进行以下修改,结果出现错误。
.forEach((k, v) -> if(v.size() > 1) System.out.println(k+" "+v.size()));
这该如何正确实现?
Collectors.groupingBy(Function.identity(), Collectors.counting())
是一种稍微更好的方法。结合一些静态导入,代码看起来会更加美观。 - Dici