栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

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

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数据结构与算法 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) 
 
 应该是有更好的方法,希望大家分享



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/245188.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号