循环并组合阵列中的时间范围

时间:2015-12-18 06:38:49

标签: javascript arrays momentjs

我正在尝试通读一组对象(即开始/结束时间)并将它们中的两个(或更多)组合在一起,如果它们是背靠背的话。

即。第一个对象的结束时间与下一个对象的开始时间相同。如果是,请将它们合并。然后使用数组中的下一个对象检查新组合的对象结束时间

这是一个简化的时间阵列:

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
             },
            ]

原始时间阵列将始终从最旧(最小开始时间)到最新(最大开始时间)排序。输出不需要按任何特定顺序排列。所有时间对象都是时刻。

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

1 个答案:

答案 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;
    });
}

评论使代码自我解释。

Working Fiddle