List查询重复值的个数,并根据重复的数目从多到少排列
Posted BigOcean
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了List查询重复值的个数,并根据重复的数目从多到少排列相关的知识,希望对你有一定的参考价值。
1 package ttt; 2 3 import java.nio.MappedByteBuffer; 4 import java.util.ArrayList; 5 import java.util.Collections; 6 import java.util.Comparator; 7 import java.util.HashMap; 8 import java.util.HashSet; 9 import java.util.List; 10 import java.util.Map; 11 import java.util.Map.Entry; 12 import java.util.Set; 13 import java.util.TreeMap; 14 import java.util.TreeSet; 15 16 public class list查重 { 17 18 public static void main(String[] args) { 19 20 List <String> wordList = new ArrayList<>(); 21 wordList.add("age"); 22 wordList.add("age"); 23 wordList.add("age"); 24 wordList.add("egg"); 25 wordList.add("dog"); 26 wordList.add("copy"); 27 wordList.add("copy"); 28 wordList.add("dog"); 29 wordList.add("dog"); 30 wordList.add("copy"); 31 wordList.add("battle"); 32 wordList.add("battle"); 33 wordList.add("battle"); 34 wordList.add("battle"); 35 wordList.add("battle"); 36 wordList.add("battle"); 37 wordList.add("age"); 38 39 rangeWords(wordList); 40 } 41 42 private static void rangeWords(List<String> wordList) { 43 Set<String> uniqueSet = new HashSet<>(wordList); 44 Map<String,Integer> maap= new HashMap<>(); 45 for (String temp : uniqueSet) { 46 int num = Collections.frequency(wordList, temp); 47 maap.put(temp, num); 48 } 49 List<Entry<String,Integer>> list = new ArrayList<>(maap.entrySet()); 50 Collections.sort(list, new Comparator<Map.Entry<String,Integer>>() { 51 @Override 52 public int compare(Map.Entry<String,Integer> cmap,Map.Entry<String,Integer> cmap2){ 53 return cmap2.getValue()-cmap.getValue(); 54 } 55 }); 56 57 printMap(list); 58 } 59 60 private static void printMap(List<Entry<String, Integer>> list) { 61 for (Map.Entry entry : list) { 62 System.out.println(entry.getKey()+" "+entry.getValue()); 63 } 64 } 65 66 }
以上是关于List查询重复值的个数,并根据重复的数目从多到少排列的主要内容,如果未能解决你的问题,请参考以下文章
给定一个只包含正整数的非空数组,返回该数组中重复次数最多的前N个数字 ,返回的结果按重复次数从多到少降序排列(N不存在取值非法的情况)