为了账号安全,请及时绑定邮箱和手机立即绑定
首页 手记 数据结构与算法 JavaScirpt描述 第 2 天

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

2019.05.23 23:31 1123浏览
来自实际项目需求,数据结构类似
做法是相同 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人点赞

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

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
30
获赞与收藏
83

关注TA,一起探索更多经验知识

同主题相似文章浏览排行榜

风间影月说签约讲师

51篇手记,涉及Java、MySQL、Redis、Spring等方向

进入讨论

Tony Bai 说签约讲师

151篇手记,涉及Go、C、Java、Python等方向

进入讨论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消