TreeMap按照value进行排序

TreeMap底层是根据红黑树的数据结构构建的,默认是根据key的自然排序来组织(比如integer的大小,String的字典排序)。所以,TreeMap只能根据key来排序,是不能根据value来排序的(否则key来排序根本就不能形成TreeMap)。

今天有个需求,就是要根据treeMap中的value排序。所以网上看了一下,大致的思路是把TreeMap的EntrySet转换成list,然后使用Collections.sor排序。代码:

[java] view plain copy

  1. public static void sortByValue() {
  2. Map<String,String> map = new TreeMap<String,String>();
  3. map.put("a", "dddd");
  4. map.put("d", "aaaa");
  5. map.put("b", "cccc");
  6. map.put("c", "bbbb");
  7. List<Entry<String, String>> list = new ArrayList<Entry<String, String>>(map.entrySet());
  8. Collections.sort(list,new Comparator<Map.Entry<String,String>>() {
  9. //升序排序
  10. public int compare(Entry<String, String> o1, Entry<String, String> o2) {
  11. return o1.getValue().compareTo(o2.getValue());
  12. }
  13. });
  14. for (Entry<String, String> e: list) {
  15. System.out.println(e.getKey()+":"+e.getValue());
  16. }
  17. }

运行结果:
d:aaaa

c:bbbb

b:cccc

a:dddd

时间: 2024-08-10 23:19:10

TreeMap按照value进行排序的相关文章

TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort()方法如何比较元素?

TreeSet要求存放的对象所属的类必须实现Comparable接口,该接口提供了比较元素的compareTo()方法,当插入元素时会回调该方法比较元素的大小.TreeMap要求存放的键值对映射的键必须实现Comparable接口从而根据键对元素进行排序.Collections工具类的sort方法有两种重载的形式,第一种要求传入的待排序容器中存放的对象比较实现Comparable接口以实现元素的比较:第二种不强制性的要求容器中的元素必须可比较,但是要求传入第二个参数,参数是Comparator接

[Java] HashMap、TreeMap、Hashtable排序

Java中对Map(HashMap,TreeMap,Hashtable等)的排序时间 首先简单说一下他们之间的区别: HashMap: 最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度.HashMap最多只允许一条记录的键为Null(多条会覆盖);允许多条记录的值为 Null.非 首先简单说一下他们之间的区别: HashMap: 最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度.HashMap

TreeMap排序实例

现有一篇英文作文,让你从中找出出现频率最高的n个单词 As can be seen from the chart that money value of annual global electronic transactions id increasing gradually in the seven years. In 1997, the money value of global electronic commerce transactions is US$ 2.6 billion, whi

TreeMap集合如何按照Value进行排序

------- android培训.java培训.期待与您交流! ---------- 我们知道,TreeMap集合是按照Key进行排序的,如何按照Value进行排序呢?现在有一个TreeMap集合 键值分别为Man类和Woman类,他们的compareTo()方法都是按照年龄排序,现在我模拟了TreeMap按照Value进行排序的方法. 算法: 1.遍历原TreeMap集合,创建个新的TreeMap集合 2.将原TreeMap集合的键值对互换,存入新的TreeMap集合 (此时,新TreeMa

TreeMap按照key排序

package com.demo.base; import java.util.Comparator;import java.util.TreeMap; public class Test { public static void main(String[] args) { //不指定排序器 TreeMap<String, String> treeMap1 = new TreeMap<String, String>(); treeMap1.put("2", &q

HashMap与TreeMap按照key和value排序

1 package com.sort; 2 3 import java.util.ArrayList; 4 import java.util.Collections; 5 import java.util.Comparator; 6 import java.util.HashMap; 7 import java.util.List; 8 import java.util.Map; 9 import java.util.Map.Entry; 10 import java.util.TreeMap;

Java Map按Value排序

Map是键值对的集合接口,它的实现类主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等. TreeMap:基于红黑树(Red-Black tree)的 NavigableMap 实现,该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法.    HashMap的值是没有顺序的,它是按照key的HashCode来实现的,对于这个无序的HashMap我们要怎么来实现排序呢?参照TreeMap的v

深入理解 hash 函数、HashMap、LinkedHashMap、TreeMap 【中】

LinkedHashMap - 有序的 HashMap 我们之前讲过的 HashMap 的性能表现非常不错,因此使用的非常广泛.但是它有一个非常大的缺点,就是它内部的元素都是无序的.如果在遍历 map 的时候, 我们希望元素能够保持它被put进去时候的顺序,或者是元素被访问的先后顺序,就不得不使用 LinkedHashMap. LinkdHashMap 继承了 HashMap,因此,它具备了 HashMap 的优良特性-高性能.在HashMap 的基础上, LinkedHashMap 又在内部维

Collections+Iterator 接口 | Map+HashMap+HashTable+TreeMap |

Collections+Iterator 接口 1. Collections 是一个操作 Set.List 和 Map 等集合的工具类 Collections 中提供了大量方法对集合元素进行排序.查询和修改等操作,还提供了对集合对象设置不可变.对集合对象实现同步控制等方法 排序操作: reverse(List):反转 List 中元素的顺序 shuffle(List):对 List 集合元素进行随机排序 sort(List):根据元素的自然顺序对指定 List 集合元素按升序排序 sort(Li