2

我正在查看一个冗余的字符串列表,例如

{ "One", "One", "One", "Two", "Three", "Three" }

计算出现次数的最佳方法是什么,然后创建一个非冗余的字符串列表,出现次数排序?

我想要的结果是这样的列表:

{ "One", "Three", "Two" }
4

3 回答 3

6

您可以在这个问题的投票最多的答案中使用技巧,了解如何按值对地图进行排序

这是一个示例实现(我在比较器中添加了泛型):

  • 您将字符串/出现添加到哈希图中
  • 将所有内容放在一个带有自定义比较器的 TreeMap 中,该比较器对值进行排序
  • 把钥匙放回列表中
public static void main(String[] args) {
    String[] strings = {"One", "One", "One", "Two", "Three", "Three"};

    //Count occurences
    Map<String, Integer> map = new HashMap<String, Integer>();

    for (String s : strings) {
        if (map.containsKey(s)) {
            map.put(s, map.get(s) + 1);
        } else {
            map.put(s, 1);
        }
    }

    ValueComparator<String, Integer> comparator = new ValueComparator<String, Integer> (map);
    Map<String, Integer> sortedMap = new TreeMap<String, Integer> (comparator);
    sortedMap.putAll(map);

    List<String> sortedList = new ArrayList<String> (sortedMap.keySet());

    System.out.println(sortedMap);
    System.out.println(sortedList);

}

static class ValueComparator<K, V extends Comparable<V>> implements Comparator<K> {

    Map<K, V> map;

    public ValueComparator(Map<K, V> base) {
        this.map = base;
    }

    @Override
    public int compare(K o1, K o2) {
         return map.get(o2).compareTo(map.get(o1));
    }
}
于 2012-07-16T13:05:29.920 回答
1

它可以在Java 8中快速完成。

Map<String, Long> sortedByCountSet =  Stream.of("One", "One", "One", "Two", "Three", "Three")
            .collect(Collectors.groupingBy(str->str,TreeMap::new,Collectors.counting()));

System.out.println(sortedByCountSet);

在这里输出:-

{一=3,三=2,二=1}

或者

Map<String, Long> sortedByCountSet = Stream.of("One", "One", "One", "Two", "Three", "Three","Five","Five")
            .collect(Collectors.groupingBy(str->str, Collectors.counting()))
            .entrySet().stream().sorted(Comparator.comparing(Map.Entry::getValue))
            .collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue,(e1, e2) -> e1,LinkedHashMap::new));

输出:-

{二=1,五=2,三=2,一=3}

于 2017-12-28T15:57:08.173 回答
0

您可以创建一个地图,浏览您的列表,每次遇到新事件时将其放入列表中并将整数值设置为 1,每次遇到重复项时,只需将该特定键的值加一即可。

然后通过哈希图中的计数创建排序列表。

或者正如其他人所建议的那样,使用 TreeMap 将允许您进行排序而不是创建 sepearet 列表。

于 2012-07-16T13:05:30.127 回答