我正在尝试通读一组对象(即开始/结束时间)并将它们中的两个(或更多)组合在一起,如果它们是背靠背的话。
即。第一个对象的结束时间与下一个对象的开始时间相同。如果是,请将它们合并。然后使用数组中的下一个对象检查新组合的对象结束时间
这是一个简化的时间阵列:
var times = [
{
start: 1,
end: 2
},{
start: 2,
end: 3
},{
start: 4,
end: 5
},{
start: 6,
end: 7
},
]
我希望(或者有一个diff数组)输出如下:
var newTimes = [
{
start: 1,
end: 3
},{
start: 4,
end: 5
},{
start: 6,
end: 7
},
]
如果连续3次变得更加棘手。
var threeTime = [
{
start: 1,
end: 2
},{
start: 2,
end: 3
},{
start: 3,
end: 5
},{
start: 6,
end: 7
},
]
以上内容应转变为:
var newThreeTimes = [
{
start: 1,
end: 5
},{
start: 6,
end: 7
},
]
原始时间阵列将始终从最旧(最小开始时间)到最新(最大开始时间)排序。输出不需要按任何特定顺序排列。所有时间对象都是时刻。
有人可以帮我解决这个问题吗?
答案 0 :(得分:3)
这是我提出的代码
function mergeArr(arr) {
// Sort the array in descending order
arr.sort(function(a, b) {
return b.start - a.start;
});
// Traverse from the top as you will need to remove the elements
// Merge the elements based on start of one and end of the previous
for (var i = arr.length - 1; i > 0; i--) {
if (arr[i].end == arr[i - 1].start) {
arr[i].end = arr[i - 1].end;
arr.splice(i - 1, 1);
}
}
// Sort it again in reverse order.
return arr.sort(function(a, b) {
return a.start - b.start;
});
}
评论使代码自我解释。