继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

数据结构与算法 JavaScirpt描述 第 2 天

纯情掉了一地
关注TA
已关注
手记 33
粉丝 29
获赞 84
来自实际项目需求,数据结构类似
做法是相同 id 的对象合并为一个对象,out 相加。


var arr = [
    { out: 50,  id: 1 },
    { out: 50,  id: 1 },
    { out: 30,  id: 2 },
    { out: 10, id: 1 },
    { out: 40, id: 2 },
    { out: 50, id: 3 }
];
 // 期望结果:
  [
      { out:110, id:1},
      { out:70,  id:2},
      { out:50,  id:3},
  ]

 //实现:
function reduce(array, key, value) {
    let a = array.concat();
    a.sort((c, n) => {
        return c[key] - n.[key]
    })
    var list = []
    for (var i = 0; i < a.length; i++) {
        var p = a[i - 1],
            c = a[i],
            n = a[i + 1];
        if (n && n[key] === c[key]
            && !p || p[key] !== c[key]) {
            var s = a.filter(j => j[key] === c[key]);
            for (var j = 1; j < s.length; j++) {
                a[i][value] += s[j][value]
            };    
            list.push(a[i])
         }
     }
     return list
 }
 reduce(arr) 
 
 应该是有更好的方法,希望大家分享



打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP