Java: How to get set of keys having same value in hashmap(Java:如何在哈希图中获取具有相同值的键集)
问题描述
我有一个如下的哈希图:
I have a hashmap as below:
1->x
2->是
3->x
4->z
现在我想知道值为 x 的所有键(ans: [1,3] ).最好的方法是什么?
Now i want to know all keys whose value is x (ans: [1,3] ). what is best way to do?
蛮力方法是遍历 map 并将所有键存储在值为 x 的数组中.
Brute force way is to just iterate over map and store all keys in array whose value is x.
有什么有效的方法吗?
谢谢
推荐答案
你可以使用 MultiMap
轻松获取所有这些重复值.
You can use a MultiMap
to easily get all those duplicate values.
Map<Integer, String> map = new HashMap<Integer, String>();
map.put(1, "x");
map.put(2, "y");
map.put(2, "z");
map.put(3, "x");
map.put(4, "y");
map.put(5, "z");
map.put(6, "x");
map.put(7, "y");
System.out.println("Original map: " + map);
Multimap<String, Integer> multiMap = HashMultimap.create();
for (Entry<Integer, String> entry : map.entrySet()) {
multiMap.put(entry.getValue(), entry.getKey());
}
System.out.println();
for (Entry<String, Collection<Integer>> entry : multiMap.asMap().entrySet()) {
System.out.println("Original value: " + entry.getKey() + " was mapped to keys: "
+ entry.getValue());
}
打印出来:
Original map: {1=x, 2=z, 3=x, 4=y, 5=z, 6=x, 7=y}
Original value: z was mapped to keys: [2, 5]
Original value: y was mapped to keys: [4, 7]
Original value: x was mapped to keys: [1, 3, 6]
根据@noahz 的建议,forMap
和 invertFrom
需要的行数更少,但阅读起来可能更复杂:
Per @noahz's suggestion, forMap
and invertFrom
takes fewer lines, but is arguably more complex to read:
HashMultimap<String, Integer> multiMap =
Multimaps.invertFrom(Multimaps.forMap(map),
HashMultimap.<String, Integer> create());
代替:
Multimap<String, Integer> multiMap = HashMultimap.create();
for (Entry<Integer, String> entry : map.entrySet()) {
multiMap.put(entry.getValue(), entry.getKey());
}
这篇关于Java:如何在哈希图中获取具有相同值的键集的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Java:如何在哈希图中获取具有相同值的键集


基础教程推荐
- Java Swing计时器未清除 2022-01-01
- 不推荐使用 Api 注释的描述 2022-01-01
- 大摇大摆的枚举 2022-01-01
- 在 Java 中创建日期的正确方法是什么? 2022-01-01
- 从 python 访问 JVM 2022-01-01
- Java 实例变量在两个语句中声明和初始化 2022-01-01
- 如何在 Spring @Value 注解中正确指定默认值? 2022-01-01
- 如何在 JFrame 中覆盖 windowsClosing 事件 2022-01-01
- 多个组件的复杂布局 2022-01-01
- 验证是否调用了所有 getter 方法 2022-01-01