Map排序方式
来源:互联网 发布:阿里云推荐系统 编辑:程序博客网 时间:2024/06/05 15:48
##Map<Key,Value>基于Value值排序###方法1: 使用TreeMap,可以参考下面的代码public class Testing { public static void main(String[] args) { HashMap<String,Double> map = new HashMap<String,Double>(); ValueComparator bvc = new ValueComparator(map); TreeMap<String,Double> sorted_map = new TreeMap<String,Double>(bvc); map.put("A",99.5); map.put("B",67.4); map.put("C",67.4); map.put("D",67.3); System.out.println("unsorted map: "+map); sorted_map.putAll(map); System.out.println("results: "+sorted_map); } } class ValueComparator implements Comparator<String> { Map<String, Double> base; public ValueComparator(Map<String, Double> base) { this.base = base; } // Note: this comparator imposes orderings that are inconsistent with equals. public int compare(String a, String b) { if (base.get(a) >= base.get(b)) { return -1; } else { return 1; } // returning 0 would merge keys } } 译注:如果不自己写Comparator,treemap默认是用key来排序###方法2:先通过linkedlist排好序,再放到LinkedHashMap中public class MapUtil { public static <K, V extends Comparable<? super V>> Map<K, V> sortByValue( Map<K, V> map ) { List<Map.Entry<K, V>> list = new LinkedList<Map.Entry<K, V>>( map.entrySet() ); Collections.sort( list, new Comparator<Map.Entry<K, V>>() { public int compare( Map.Entry<K, V> o1, Map.Entry<K, V> o2 ) { return (o1.getValue()).compareTo( o2.getValue() ); } } ); Map<K, V> result = new LinkedHashMap<K, V>(); for (Map.Entry<K, V> entry : list) { result.put( entry.getKey(), entry.getValue() ); } return result; } }
这两种方法,我简单测试了下,如果map的size在十万级别以上,两者的耗时都是几百毫秒,第二个方法会快一些。否则,第一个方法快一些。因此,如果你处理的map,都是几十万级别以下的大小,两种方式随意使用,看个人喜欢了
阅读全文
0 0
- Map排序方式
- Map排序实现方式
- Map按key排序和value排序方式
- Map——自然排序与插入排序创建方式
- C++的map中key的排序方式
- Map排序
- map排序
- MAP排序
- Map排序
- Map排序
- map 排序
- map 排序
- map排序
- map 排序
- MAP排序
- Map排序
- map排序
- map排序
- MYSQL批量插入数据
- glut绘图函数
- Cocos2d-x 程序是如何开始运…
- 关于cocos2d-x无法包含头文件的问…
- 关于Tiled Map Editor载…
- Map排序方式
- tiled地图加载错误
- Python input 与raw_input的区别。
- 错误:boldparagraph.cpp(5) …
- Android Kotlin初体验
- 用Eclipse和wxpython搭建一…
- JPA ORM组件
- 关于gluCylinder函数的用法…
- OpenGL加载纹理深入详解。