为了账号安全,请及时绑定邮箱和手机立即绑定

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

来自实际项目需求,数据结构类似
做法是相同 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) 
 
 应该是有更好的方法,希望大家分享



点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消