Web 開発やデータ分析では、単語の出現頻度を理解することが重要です。これを達成するために、Java 8 を使用してリスト内の単語の頻度をカウントする方法を詳しく説明します。
Java 8 の Stream API は、単語用のエレガントなソリューションを提供します。周波数のカウント。まず、単語のリストを作成します:
ListwordsList = Lists.newArrayList("hello", "bye", "ciao", "bye", "ciao");
コア ロジックには、単語を ID ごとにグループ化し、出現回数をカウントすることが含まれます。
Mapcollect = wordsList.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));
これにより、各キーが一意の単語であり、対応する値がその頻度であるマップが生成されます。出力は次のようになります:
{ciao=2, hello=1, bye=2}
Counting Integer Values
整数値が必要な場合長い値の代わりに、
Mapcollect = wordsList.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.summingInt(e -> 1)));
次の値に基づいてマップを並べ替えます。降順、使用:
LinkedHashMapcountByWordSorted = collect.entrySet() .stream() .sorted(Map.Entry.comparingByValue(Comparator.reverseOrder())) .collect(Collectors.toMap( Map.Entry::getKey, Map.Entry::getValue, (v1, v2) -> { throw new IllegalStateException(); }, LinkedHashMap::new ));
このステップは、キーが単語を表し、値がそのソートされた頻度を表す、ソートされた LinkedHashMap を返します。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3