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);
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询