java 怎么对于 map value 排序

 我来答
歪_听得到吗
2017-10-22 · TA获得超过4004个赞
知道大有可为答主
回答量:1887
采纳率:44%
帮助的人:985万
展开全部
package Map;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.TreeMap;

public class SortMap {
public static void main(String[] args) {
Map map=new TreeMap ();
map.put("图书" , 4);
map.put("音像" , 6);
map.put("素材" , 9);
map.put("音乐" , 8);
map.put("影视" , 7);
map.put("动漫" , 4);
map.put("歌曲" , 3);
map.put("图片" , 2);
map.put("图标" , 6);
ArrayList<Map.Entry<String,Integer>> entries= sortMap(map);
for( int i=0;i<5;i++){
System. out.print(entries.get(i).getKey()+":" +entries.get(i).getValue());
}
}
public static ArrayList<Map.Entry<String,Integer>> sortMap(Map map){
List<Map.Entry<String, Integer>> entries = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());
Collections.sort(entries, new Comparator<Map.Entry<String, Integer>>() {
public int compare(Map.Entry<String, Integer> obj1 , Map.Entry<String, Integer> obj2) {
return obj2.getValue() - obj1.getValue();
}
});
return (ArrayList<Entry<String, Integer>>) entries;
}
}12345678910111213141516171819202122232425262728293031323334353637

此时是按照降序排序,如果想升序排序,则Comparator的 返回 改为obj1.getValue() - obj2.getValue();即可
总结:由于TreeMap主要是针对key进行默认排序的,但是有的时候我们需要对value进行排序,这时候主要采取的策略是 将map变为List,然后利用Collections.sort进行排序,同时重写Comparator方法,即可。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式