其他分享
首页 > 其他分享> > js 格式化双层数组使得时间复杂度为O(n)的尝试

js 格式化双层数组使得时间复杂度为O(n)的尝试

作者:互联网

格式化双层数组使得时间复杂度为O(n)的尝试

  1. 提取关键数据,将双层数组扁平化为单层
  2. 单层再做转换
const infos = [
    {
        time: '2022-02-21',
        data: [{
            Duration: 22,
            Spec: "h264"
        },
        {
            Duration: 33,
            Spec: "h265_hd"
        },
        {
            Duration: 44,
            Spec: "h264_4k"
        }]
    },
    {
        time: '2022-02-22',
        data: [{
            Duration: 55,
            Spec: "h264"
        },
        {
            Duration: 66,
            Spec: "h265_hd"
        },
        {
            Duration: 77,
            Spec: "h264_4k"
        }]
    }
]

const _map = list => list
    .reduce((prev, cur) => prev.data.concat(cur.data))
    .reduce((total, { Duration, Spec }) => Object.assign(total, { [Spec]: (total[Spec] || []).concat(Duration) }), {})
const _list = map => Object.entries(map).map(([name, data]) => ({ name, data }))
_list(_map(infos))

标签:map,格式化,h264,复杂度,list,js,Duration,data,Spec
来源: https://www.cnblogs.com/ltfxy/p/15929493.html