pat*_*oid 3 java sortedmap guava
我想知道有什么更好的方法可以在大型SortedMap中找到大于输入值的第一个值,而不是在下面的示例中循环遍历所有值.或者,如果SortedMap是用于此的最佳结构.
这可以通过谷歌收藏来实现吗?提前致谢
public class mapTest {
public static void main(String[] args) {
SortedMap<Double, Object> sortedMap = new TreeMap<Double, Object>();
sortedMap.put(30d, "lala");
sortedMap.put(10d, "foo");
sortedMap.put(25d, "bar");
System.out.println("result: " + findFirstValueGreaterThan(sortedMap, 28d));
}
public static Object findFirstValueGreaterThan(SortedMap<Double, Object> sortedMap, Double value) {
for (Entry<Double, Object> entry : sortedMap.entrySet()) {
if (entry.getKey() > value) {
// return first value with a key greater than the inputted value
return entry.getValue();
}
}
return null;
}
}
Run Code Online (Sandbox Code Playgroud)
一切都在文档中:
ceilingKey(K key)
返回大于或等于给定键的最小键,如果没有这样的键,则返回null.
所以,
findFirstValueGreaterThan(sortedMap, 28d)
Run Code Online (Sandbox Code Playgroud)
应该
sortedMap.ceilingKey(28d)
Run Code Online (Sandbox Code Playgroud)
但要注意"大于"和"大于或等于"之间的差异.
| 归档时间: |
|
| 查看次数: |
2415 次 |
| 最近记录: |