• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

ljacqu / wordeval / 14540892325

18 Apr 2025 07:50PM UTC coverage: 51.4% (-12.1%) from 63.456%
14540892325

push

github

ljacqu
Merge remote-tracking branch 'origin/master' into dependencies

239 of 546 branches covered (43.77%)

93 of 383 new or added lines in 27 files covered. (24.28%)

5 existing lines in 4 files now uncovered.

679 of 1321 relevant lines covered (51.4%)

3.0 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

37.5
/src/main/java/ch/jalu/wordeval/evaluators/impl/Anagrams.java
1
package ch.jalu.wordeval.evaluators.impl;
2

3
import ch.jalu.wordeval.dictionary.Word;
4
import ch.jalu.wordeval.evaluators.AllWordsEvaluator;
5
import ch.jalu.wordeval.evaluators.result.WordGroupWithKey;
6
import com.google.common.collect.ArrayListMultimap;
7
import com.google.common.collect.HashMultimap;
8
import com.google.common.collect.ListMultimap;
9
import com.google.common.collect.Multimaps;
10
import com.google.common.collect.SetMultimap;
11
import lombok.Getter;
12

13
import java.util.ArrayList;
14
import java.util.Arrays;
15
import java.util.Collection;
16
import java.util.Comparator;
17
import java.util.HashSet;
18
import java.util.List;
19
import java.util.Set;
20
import java.util.function.Function;
21

22
/**
23
 * Collects anagram groups (e.g. "acre", "care", "race").
24
 */
25
public class Anagrams implements AllWordsEvaluator {
2✔
26

27
  @Getter
6✔
28
  private final List<WordGroupWithKey> results = new ArrayList<>();
29

30
  @Override
31
  public void evaluate(Collection<Word> words) {
32
    SetMultimap<String, Word> wordsBySortedChars = words.stream()
4✔
33
      .collect(Multimaps.toMultimap(this::sortLettersAlphabetically, Function.identity(), HashMultimap::create));
6✔
34

35
    Multimaps.asMap(wordsBySortedChars).forEach((sequence, groupedWords) -> {
5✔
36
      if (groupedWords.size() > 1) {
4✔
37
        results.add(new WordGroupWithKey(groupedWords, sequence));
9✔
38
      }
39
    });
1✔
40
  }
1✔
41

42
  @Override
43
  public ListMultimap<Object, Object> getTopResults(int topScores, int maxLimit) {
NEW
44
    Comparator<WordGroupWithKey> comparator = Comparator.comparingInt((WordGroupWithKey group) -> group.getWords().size())
×
NEW
45
        .thenComparing(group -> group.getKey().length())
×
NEW
46
        .reversed(); // todo: unit test
×
47

NEW
48
    List<WordGroupWithKey> sortedResult = results.stream()
×
NEW
49
        .sorted(comparator)
×
NEW
50
        .toList();
×
51

NEW
52
    Set<Integer> uniqueValues = new HashSet<>();
×
NEW
53
    ListMultimap<Object, Object> filteredResults = ArrayListMultimap.create();
×
NEW
54
    for (WordGroupWithKey wordGroup : sortedResult) {
×
NEW
55
      int score = wordGroup.getWords().size();
×
NEW
56
      if (uniqueValues.add(score) && uniqueValues.size() > topScores) {
×
NEW
57
        break;
×
58
      }
NEW
59
      List<String> wordList = wordGroup.getWords().stream()
×
NEW
60
          .map(Word::getRaw)
×
NEW
61
          .toList();
×
NEW
62
      filteredResults.put(score, wordList);
×
NEW
63
      if (filteredResults.size() >= maxLimit) {
×
NEW
64
        break;
×
65
      }
NEW
66
    }
×
67

NEW
68
    return filteredResults;
×
69
  }
70

71
  private String sortLettersAlphabetically(Word word) {
72
    char[] chars = word.getWithoutAccentsWordCharsOnly().toCharArray();
4✔
73
    Arrays.sort(chars);
2✔
74
    return new String(chars);
5✔
75
  }
76
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc