Java 8에서 단어 빈도 계산
Java 8을 사용하여 목록에 있는 단어의 빈도를 계산하는 방법은 무엇입니까?
<code class="java">List<String> wordsList = Lists.newArrayList("hello", "bye", "ciao", "bye", "ciao");</code>
결과는 다음과 같아야 합니다.
<code class="java">{ciao=2, hello=1, bye=2}</code>
처음에는 맵 앤 리듀스 방식을 사용할 것으로 예상했지만 실제 방식은 약간 다릅니다.
<code class="java">Map<String, Long> collect = wordsList.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));</code>
또는 정수 값의 경우:
<code class="java">Map<String, Integer> collect = wordsList.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.summingInt(e -> 1)));</code>
EDIT
값별로 지도를 정렬하는 방법도 추가했습니다.
<code class="java">LinkedHashMap<String, Long> countByWordSorted = 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 ));</code>
위 내용은 Java 8을 사용하여 목록의 단어 빈도를 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!