Im, используя следующий код для создания хэш-карты, а затем сортировку значений в хэш-карте с помощью treemap и компаратора. Однако выход довольно неожиданный. Так любые мысли относительно того, что Im делая неправильно было бы полезноСортировка HashMap по значению с помощью TreeMap и Comparator
Код
public static void main(String[] args) {
System.out.println("Most freq"+mostFreq(" i me hello hello hello me"));
}
public static String[] mostFreq(String str){
if ((str==null)||(str.trim().equalsIgnoreCase("")))
return null;
String[] arr = new String[10];
String[] words= str.split(" ");
Map <String,Integer> map = new HashMap<String,Integer>();
for (String word :words)
{
int count =0;
if (map.containsKey(word))
{
count= map.get(word);
map.put(word, count+1);
}
else
map.put(word, 1);
}
MyComparator comp= new MyComparator(map);
Map<String,Integer> newMap= new TreeMap(comp);
newMap.putAll(map);
Iterator it= newMap.entrySet().iterator();
while (it.hasNext())
{
Map.Entry pairs = (Map.Entry) it.next();
System.out.println("Key "+pairs.getKey()+"-- value"+pairs.getValue());
}
return arr;
}
Вот компаратор
package samplecodes;
import java.util.Comparator;
import java.util.Map;
public class MyComparator implements Comparator {
Map map;
public MyComparator(Map map){
this.map=map;
}
@Override
public int compare(Object o1, Object o2) {
return ((Integer)map.get(o1) >(Integer)map.get(o2)? (Integer)map.get(o1):(Integer)map.get(o2));
}
}
И выход имеет вид
me-2
hello-3
i-3
Ваш код не производит этот вывод. Вы уверены, что это тот, который вы используете? – Pshemo
Также можно взглянуть на [how-to-sort-a-mapkey-value-on-the-values-in-java] (http://stackoverflow.com/questions/109383/how-to-sort-a -mapkey-value-on-the-values-in-java) – Pshemo
много неприятного запаха в вашем коде: пожалуйста, добавьте тип generics type param для вашей карты, итератора и т. д. В 'mostFreq()' вы возвращаете 'arr', который это просто пустой массив String, который никогда не был затронут в методе. Я также отвечаю в ответ на вашу логическую проблему. –