删除和更新 javascript 中对象数组中的重叠索引

Remove and update overlapping indexes in array of object in javascript

提问人:abinas patra 提问时间:4/29/2022 最后编辑:abinas patra 更新时间:4/29/2022 访问量:277

问:

我有一个带有重叠索引的对象数组。

[
  //1st object
  {
    start: 3,
    end: 10
  },
  //2nd object
  {
    start: 5,
    end: 8
  },
  //3rd object
  {
    start: 11,
    end: 30
  },
  //4th object
  {
    start: 0,
    end: 4
  }
]

我想通过修改和删除一些重叠对象来创建数组新数组,即 case1:- 如果任何对象在间隔内完全掉落,则删除,即可以删除第二个对象,因为它落在第一个对象中 Case2:- 如果任何对象部分落在间隔内,我想更新索引。这样所有的对象都可以是不同的

最终结果如下图所示。

[
  //I increased 1st object by 2 as 4th object's end index is 4. I increased (end of 4th - start of 1st) + 1
  {
    start: 5,
    end: 12
  },
  //I removed 2nd object
  // I changed the 3rd object by 2 because it's overlapping with the newly created `{start:5, end:12}` object
  {
    start: 13,
    end: 32
  },
  // No change in 4th object.
  {
    start: 0,
    end: 4
  }
]

任何建议,我怎样才能解决这个问题。 我尝试了以下方法来修改数组。

const updateArray = arr => {
  let sortArr = arr.sort((a,b)=> a.start - b.start || a.end - b.end);
  let newArr = sortArr.reduce((r,a) =>{
    let obj = r[r.length - 1] || {};
      if (obj.start <= a.start && a.start <= obj.end) {
        if (obj.end < a.end) {
          a.start = obj.end + 1;
        } else {
          obj.start = a.end + 1;
        }
      }
      return r.concat(a);
  },[]);
  return newArr;
}
数组 javascript 对象 重叠匹配

评论

1赞 Nick Bailey 4/29/2022
你试过什么。一如既往,StackOverflow 不是一个代码编写服务,它是一个调试帮助平台。

答:

0赞 NightEye 4/29/2022 #1

我假设排序的输出会很好(因为您正在使用一个)。如果是这样,那么下面的脚本将解决它。

脚本:

function modifyArray(array) {
  var prevEnd;
  array = array.sort((x,y) => x.start - y.start);

  for(i = 0; i < array.length; i++) {  
    if(!i) { 
      prevEnd = array[i].end;
      continue;
    }
    if(array[i].start < prevEnd && array[i].end > prevEnd) { 
      diff = prevEnd + 1 - array[i].start;
      array[i].start += diff;
      array[i].end += diff; 
      prevEnd = array[i].end;
    }
    else if(array[i].start > prevEnd) 
      continue;
    else 
      array.splice(i--, 1);
  }
  return array;
}

function test() {
  let array1 = [ { start: 3, end: 10 },
                { start: 5, end: 8 },
                { start: 11, end: 30 },
                { start: 0, end: 4 } ];
  let array2 = [{start: 10, end: 12}, {start:17, end: 19}]

  console.log(modifyArray(array1))
  console.log(modifyArray(array2))
}

输出:

output1

评论

0赞 abinas patra 4/29/2022
谢谢你的剧本。我尝试举个例子.它不是一个重叠的数组,但由于其他部分,它删除了最后一个对象。如果没有重叠,则脚本不应修改数组。[{start: 10, end: 12}, {start:17, end: 19}]
0赞 NightEye 4/29/2022
嗨,@abinaspatra,对不起,我忘记了那个条件,只是在那个特定的条件上使用,并且已经修改了上面的脚本。请测试更新的。continue