Java - 如何从最接近特定数字的hashmap中查找值?

时间:2013-03-12 22:27:53

标签: java arrays hashmap

您好我有一个HashMap<String, Double>,还有一个返回称为answer的双精度值的函数。我想检查HashMap中哪个值最接近答案,然后获取该值的键并打印出来。

HashMap<String, Double> output = new HashMap<String, Double>();


contents
("A", 0)
("B", 0.25)
("C", 0.5)
("D", 0.75)
("E", 1)

假设我的一个函数的答案是0.42,我如何检查它最接近的值,然后获取该值的键。我无法切换HashMap的键和值(因为前一个函数将值分配给每个字母),否则最好遍历每个键并获取值。

4 个答案:

答案 0 :(得分:8)

如果您的值是唯一的,则可以使用实现TreeMapNavigableMap,其中包含ceilingKeyfloorKey方法:

    NavigableMap<Double, String> map = new TreeMap<>();
    map.put(0d, "A");
    map.put(0.25, "B");
    map.put(0.5, "C");
    map.put(0.75, "D");
    map.put(1d, "E");

    double value = 0.42;
    double above = map.ceilingKey(value);
    double below = map.floorKey(value);

    System.out.println(value - below > above - value ? above : below); //prints 0.5

注意:如果value小于(最大),则两个方法都可以返回null。

答案 1 :(得分:4)

使用HashMap,您必须浏览每个条目。

但是,如果性能很重要,您将以这种方式查找多个条目,则可以创建另一个集合:哈希映射中的条目列表或数组,按值。然后,您可以进行二进制搜索,以更有效地查找具有最近值的条目,并返回密钥。当然,如果你每个地图只打算这样做一次就没有用......

答案 2 :(得分:0)

“最接近”的概念对于Hashed数据结构并没有多大意义。有效散列算法的主要目标是避免碰撞,这与紧密度直接相反。你是否有碰撞。

如果你问这个有序的密钥数据结构(例如TreeMap),答案会有所不同。

答案 3 :(得分:0)

HashMap不是最好的结构。 您可以获取output.keySet()并检查每个值,例如:

for(String key:output.keySet()){
   Double temp=Math.abs(output.get(key)-answer);
   if(temp<min){
     min=temp;
     nearest=key;
   }
}

但这不是最好的方法。 你被迫使用hashmap? 顺便说一句,如果您总是有五个答案可以检查,这不是问题......