1

我正在使用 Map.entrySet() 显示当前按键排序的 TreeMap。但是,我想显示按值和键排序的内容。这可能吗?如果是,我会怎么做?

编辑:改写:

我目前正在显示按键排序的树形图。我想显示它最初按值排序,但如果值相同,我希望键以升序显示。

4

2 回答 2

2

我不确切知道您要实现什么 - TreeMap 中的键是唯一的,因此如果您按键对内容进行排序,按值排序是没有意义的。如果您想要两个列表,一个按键排序,另一个按值排序,您可以使用两个 TreeMap 或使用特殊容器,例如Bimap

于 2011-10-22T10:37:10.997 回答
1

使用比较器对地图中的条目对象进行排序。

public class MyComparator implements Comparator<Entry<String, String>> {
    @Override
    public int compare(Entry<String, String> left, Entry<String, String> right) {
        int valueComp = left.getValue().compareTo(right.getValue());
        if (valueComp != 0)
            return valueComp;
        int keyComp = left.getKey().compareTo(right.getKey());
        return keyComp;
    }
}

@Test
public void testSorting() throws Exception {
    Map<String, String> tree = new TreeMap<String, String>();
    tree.put("D", "A");
    tree.put("A", "A");
    tree.put("F", "C");
    tree.put("E", "B");
    tree.put("C", "A");
    tree.put("B", "B");
    Set<Entry<String, String>> entrySet = tree.entrySet();
    Comparator<? super Entry<String, String>> comparator = new MyComparator();
    TreeSet<Entry<String, String>> sorted = new TreeSet<Entry<String, String>>(comparator);
    sorted.addAll(entrySet);
    for (Entry<String, String> entry : sorted) {
        System.out.println(entry);
    }
}

结果:

A=A
C=A
D=A
B=B
E=B
F=C
于 2011-10-22T13:21:59.990 回答