java 在treemap 中怎么获取有相同值的键

如题所述

循环遍历,查询到值相同的,就记录下, 然后保存到另一个Map即可

下面按照要求,写了一个参考代码,读完测试一下就懂了

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;

public class Demo {
public static void main(String[] args) {
TreeMap<String, Integer> map = new TreeMap<String, Integer>();
map.put("a", 1);
map.put("b", 2);
map.put("c", 1);
map.put("d", 2);

//result 的键 是 Integer, 值是ArrayList,因为需要存的可能不是一个
HashMap<Integer, ArrayList<String>> result = new HashMap<Integer, ArrayList<String>>();
for (Map.Entry<String, Integer> entry : map.entrySet()) {
String k=entry.getKey();
int v=entry.getValue();
if(result.containsKey(v)){//如果存在
result.get(v).add(k);
}else{//如果不存在
result.put(v, new ArrayList<String>(Arrays.asList(k)));
}
}
System.out.println(result);
}
}

温馨提示:答案为网友推荐,仅供参考
相似回答