0

我用javascript中的对象创建了一个数组。这就是我得到的:

object[
   {position:1, value:23}, 
   {position:34, value:22 }, 
   {position:2, value:10},
   {position:35,value:9}.....
]

所以我想创建一个for循环,删除那些目标(例如目标=(object1.position - object2.position)*-1)低于18的对象到以前的对象。

例如:object[2].position 与 object[0].position 相差 1 个位置,因此不再需要 object[2]。object[3] ... 35 - 34 = 1 / 1<18 / object[3] 也不需要。

这就是我写的:

myfullarray = [
    {pos:1,value:23},
    {pos:34,value:22},
    {pos:2,value:10},
    (...)
]
myarray = [];
myarray[0] = {
    pos:myfullarray[0].pos,
    value:myfullarray[0].value
}

for(i=1;i<myarray.length;i++){
    for(d=i;d>0;d--){
      mydest = myfullarray[i].pos-myfullarray[d].pos;
      if(mydest<0){
        mydest *= -1
      }
      if(mydest<18){
      }else{

        myarray[myarray.length + 1] = {
          value:myfullarray[i].value,
          pos:myfullarray[i].pos
        };
      }
    }
 }

有人可以帮我解决这个问题吗?

4

2 回答 2

0

如果你想更接近你的原始算法,这应该会做。

myfullarray = [
    {position:1, value:23}, 
    {position:34, value:22 }, 
    {position:2, value:10},
    {position:35,value:9}
]
myarray = [];
myarray[0] = {
    pos:myfullarray[0].position,
    value:myfullarray[0].value
}
myfullarray.splice(0,1);

var mindest = 18;

for(i=0;i<myarray.length;i++){
    var myobject = myarray[i];
    for(d=i;d<myfullarray.length;d++){
      mydest = myobject.position-myfullarray[d].position;
      if(mydest<0){
        mydest *= -1
      }
      if(mydest<mindest){
          myfullarray.splice(d, 1);
      }
    }

    if (i < myfullarray.length) {
        myarray.push(myfullarray[i]);
        myfullarray.splice(i,1);
    }
}
于 2013-09-24T21:05:42.610 回答
0

这是一个避免二次迭代的建议。创建一个新数组。然后遍历整个数组,跟踪到目前为止的最小和最大位置,如果当前对象的位置距离最小值和最大值小于 18,则将其添加到新数组中。

编辑:这是代码的快速编写。

myFullArray = ...
myArray = [];
myArray[0] = myFullArray[0];
var min = myArray[0].pos;
var max = myArray[0].pos;
var current;
for (i = 1; i < myFullArray.length; i++) {
    current = myFullArray[i].pos;
    if (Math.abs(current - min) < 18) && Math.abs(current - max) < 18)
    {
        myArray.push(myFullArray[i]);
        if (current < min)
            min = current;
        else if (current > max)
            max = current;
    }
}
于 2013-09-24T20:52:54.513 回答