各要素の出現回数をカウントするために次のスニペットを記述しました。はるかに短い方法でこれを達成することは可能ですか?整数配列内の各要素のJavaカウントの発生
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()));
これを行う正しい方法は何ですか。後者の問題については
すっごいです!それを考えなかった。 – DhiwaTdG
'Collectors.groupingBy(Function.identity()、Collectors.counting())'を使ってより良い方法があります。静的なインポートの束では、それはより良く見える – Dici
また、それを印刷する代わりにとして結果を返すことは可能ですか? –
DhiwaTdG