map排序(java)

map排序

以下方法可套用

package com.youdao.baike.test;
import java.util.*;
public class Test{
public static void main(String[] args) {
    KeySort();
    KeyIntSort();
    ValueSort();
    ValueIntSort();
}
    public static void KeySort() {
    Map<String, String> map = new TreeMap<String, String>(
            new Comparator<String>() {
                public int compare(String obj1, String obj2) {
                    // 降序排序
                    return obj2.compareTo(obj1);
                }
            });
    map.put("bd", "ccccc");
    map.put("da", "aaaaa");
    map.put("cd", "bbbbb");
    map.put("a", "aa");
    Set<String> keySet = map.keySet();
    Iterator<String> iter = keySet.iterator();
    while (iter.hasNext()) {
        String key = iter.next();
        System.out.println(key + ":" + map.get(key));
    }
}
public static void KeyIntSort() {
    Map<Integer, String> map = new TreeMap<Integer, String>();
    map.put(1, "ddddd");
    map.put(3, "bbbbb");
    map.put(2, "aaaaa");
    map.put(4, "ccccc");
    //这里将map.entrySet()转换成list
    List<Map.Entry<Integer,String>> list = new ArrayList<Map.Entry<Integer,String>>(map.entrySet());
    //然后通过比较器来实现排序
    Collections.sort(list,new Comparator<Map.Entry<Integer,String>>() {
        //升序排序
        public int compare(Map.Entry<Integer, String> o1,
                           Map.Entry<Integer, String> o2) {
            return o1.getKey() - o2.getKey();
        }
    });
    for(Map.Entry<Integer,String> mapping:list){
        System.out.println(mapping.getKey()+":"+mapping.getValue());
    }
}
public static void ValueSort() {
    Map<String, String> map = new TreeMap<String, String>();
    map.put("a", "ddddd");
    map.put("c", "bbbbb");
    map.put("d", "aaaaa");
    map.put("b", "ccccc");
    //这里将map.entrySet()转换成list
    List<Map.Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(map.entrySet());
    //然后通过比较器来实现排序
    Collections.sort(list,new Comparator<Map.Entry<String,String>>() {
        //升序排序
        public int compare(Map.Entry<String, String> o1,
                           Map.Entry<String, String> o2) {
            return o1.getValue().compareTo(o2.getValue());
        }
    });
    for(Map.Entry<String,String> mapping:list){
        System.out.println(mapping.getKey()+":"+mapping.getValue());
    }
}
public static void ValueIntSort() {
    Map<String, Integer> map = new TreeMap<String, Integer>();
    map.put("a", 2);
    map.put("c", 3);
    map.put("d", 1);
    map.put("b", 4);
    //这里将map.entrySet()转换成list
    List<Map.Entry<String,Integer>> list = new ArrayList<Map.Entry<String,Integer>>(map.entrySet());
    //然后通过比较器来实现排序
    Collections.sort(list,new Comparator<Map.Entry<String,Integer>>() {
        //升序排序
        public int compare(Map.Entry<String, Integer> o1,
                           Map.Entry<String, Integer> o2) {
            //return o1.getValue().compareTo(o2.getValue());
            return o1.getValue() - o2.getValue();
        }
    });
    for(Map.Entry<String,Integer> mapping:list){
        System.out.println(mapping.getKey()+":"+mapping.getValue());
    }
}
}

转载于:https://my.oschina.net/vintnee/blog/699520

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值