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

Mat*_*ins 3 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)
Run Code Online (Sandbox Code Playgroud)

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

ass*_*ias 8

如果您的值是唯一的,您可以使用TreeMap,它实现了NavigableMap,它具有以下优点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
Run Code Online (Sandbox Code Playgroud)

注意:如果value比最小/最大键少(相应大于),则两种方法都可以返回null .