我想按值排序我的HashMap
(或TreeMap
)。我通过创建一个自定义Comparator
来达到这个目的。但是,无论何时我再次输入HashMap
的所有输入项,我都会得到重复项。比较器在TreeMap中创建副本
如何根据值排序而不创建重复项?
CODE
public class Test {
public static void main(String[] args) {
HashMap<Integer, String> hMap = new HashMap<Integer, String>();
ValueComparator vc = new ValueComparator(hMap);
TreeMap<Integer, String> tMap = new TreeMap<Integer, String>(vc);
hMap.put(0, "b");
hMap.put(1, "c");
hMap.put(2, "a");
tMap.putAll(hMap);
tMap.putAll(hMap);
for (Map.Entry<Integer, String> entry : tMap.entrySet()) {
System.out.println(entry.getKey() + " " + entry.getValue());
}
}
}
class ValueComparator implements Comparator<Integer> {
Map<Integer, String> base;
public ValueComparator(Map<Integer, String> base) {
this.base = base;
}
public int compare(Integer a, Integer b) {
if (base.get(a).charAt(0) >= base.get(b).charAt(0))
return 1;
else return -1;
}
}
OUTPUT
2 a
2 a
0 b
0 b
1 c
1 c
您的输入是什么?你为什么要比较第0个字符,在你的情况下是否可行的比较?为什么在平等而不是0的情况下返回1? – 2014-12-06 15:57:16
这只是我的问题的演示。但正如你所说,我并没有完全实现比较器! – TomTom 2014-12-06 16:08:46