java map比较值的大小_java map按照value值来比较大小并且返回最终结果

package com.zuidaima.util;

import java.util.Comparator;

import java.util.HashMap;

import java.util.Map;

import java.util.TreeMap;

public class ValueComparator implements Comparator {

Map base;

public ValueComparator(Map base) {

this.base = base;

}

public int compare(Long a, Long b) {

if (base.get(a).doubleValue() >= base.get(b).doubleValue()) {

return -1;

} else {

return 1;

}

}

public static > Map sortByValues(

final Map map) {

Comparator valueComparator = new Comparator() {

public int compare(K k1, K k2) {

int compare = map.get(k2).compareTo(map.get(k1));

if (compare == 0)

return 1;

else

return compare;

}

};

Map sortedByValues = new TreeMap(valueComparator);

sortedByValues.putAll(map);

return sortedByValues;

}

public static void main(String[] args) {

HashMap map = new HashMap();

map.put(1l, 99.5);

map.put(2l, 67.2);

map.put(3l, 67.5);

map.put(4l, 67.6);

ValueComparator bvc = new ValueComparator(map);

TreeMap sorted_map = new TreeMap(bvc);

System.out.println("unsorted map: " + map);

sorted_map.putAll(map);

System.out.println("results: " + sorted_map);

Map sorted_map2 = sortByValues(map);

System.out.println("results2: " + sorted_map2);

}

}

输出结果:

unsorted map: {1=99.5, 2=67.2, 3=67.5, 4=67.6}

results: {1=99.5, 4=67.6, 3=67.5, 2=67.2}

results2: {1=99.5, 4=67.6, 3=67.5, 2=67.2}

通过key比较大小的原理类似,大家改写下就好了。enjoy it。

原文:http://blog.csdn.net/yaerfeng/article/details/28592999

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值