双精度数组中的滤波器元素

时间:2012-11-16 00:55:33

标签: java algorithm

给出一个double的数组

1.0 2.0 3.0 ... 10.0 

输出

filter(3,7)  should produce 3.0,4.0,5.0,6.0,7.0

filter(5,7.5) should produce 5.0,6.0,7.0,8.0

filter(6.6,6.7) should produce 6.0,7.0

基于filter方法

public List<Double> filter(double start, double end){
    List<Double> list = Arrays.asList(1.0,2.0,3.0,4.0,5.0,6.0,7.0,8.0,9.0,10.0);
    List<Double> resultList = new ArrayList<Double>(); 

     //search in list for elements such that it includes the lower bounds and upper bound of search
     //i.e. 6.6 should also include 6.0 and 7.0 from the array. 


   return resultList;

}

这看起来很简单,但我无法想出一个我很满意的解决方案,因此这个问题。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:2)

for循环解决方案应该是最简单的,因为您可以使用Math.floor函数来获取所需列表的开头:

for (double d = Math.floor(start); d <= Math.ceil(end); d += 1.0)
    list.add(d);