0

我现在已经遇到过几次这个问题,但我没有一个很好的解决方案。

假设我有一个不固定间隔的简单数字数组,myArray. 我想要一个可以取整数(可能为负数)并返回数组中最接近的值的函数。在我的示例中,我希望它返回850

我想我需要使用upperandlower变量来计算出哪个数组值最接近我传入的值。

我是否走在正确的轨道上,或者是否有更有效的方法来实现这一目标,有人可以在正确的方向上推动我吗?

这是我到目前为止所拥有的:

var myArray = [0,850,1800,2500,3300];

function snapTo(value){
    var upper = -1;
    var lower = -1;

    // if the value is bigger than the last array value
    if(value > myArray[myArray.length-1]){
        upper = myArray[myArray.length-1];
        lower = myArray[myArray.length-2];
    // if the value is smaller than the first array value
    } else if(value < myArray[0]){
        upper = myArray[1];
        lower = myArray[0];
    } else {
        for(var i = 0, i < myArray.length, i++){
            if(value > myArray[i]){
                upper = myArray[i];
                lower = myArray[i-1];
                break;
            }
        }
    }

    // x being the index of the closest array value to the one passed in
    return myArray[x];
}

snapTo(1200);
4

2 回答 2

3

您先生正在寻找二进制搜索而不是那个!

于 2012-10-23T11:41:46.870 回答
1

我会提醒您,您不需要特别检查该值是大于还是小于前一个数组值。相反,只需计算出您的目标值和“当前”数组元素之间的绝对差异。并将其与迄今为止的最佳差异进行比较,以确定该数组索引是否是迄今为止的获胜候选者......

于 2012-10-23T11:42:09.710 回答