zoukankan      html  css  js  c++  java
  • js 算法 两个数组比较去重,性能优化

    如果追求性能,可以采用空间换时间的做法,在JS中最常见的处理方式就是构建Object,因为Object查找key的时间复杂度是O(1),而数组是O(n)

    <!DOCTYPE html>
    <html>
    <head>
        <title>js两个数组比较去重</title>
    </head>
    <body>
    <script type="text/javascript">
        // 如果追求性能,可以采用空间换时间的做法,在JS中最常见的处理方式就是构建Object,因为Object查找key的时间复杂度是O(1),而数组是O(n)
        const list1 = [
            {id: 0, name: 'xiaomin'},
            {id: 1, name: 'xiaohong'},
        ];
        const list2 = [
            {id: 0, name: 'xiaomin'},
            {id: 1, name: 'xiaohong'},
            {id: 3, name: 'xiaomin'},
            {id: 4, name: 'xiaohong'},
        ];
        // 首先构造Object
        const idSet = list1.reduce((acc, v) => {
            acc[v.id] = true;
            return acc;
        }, {});
        console.log('构造Object', idSet)
        // 遍历list2,去掉在idSet中存在的id
        const result = list2.filter(v => !idSet[v.id]);
        const repeat = list2.filter(v => idSet[v.id]);
        console.log('去重后的result', result)
        console.log('重复的repeat', repeat)
    </script>
    </body>
    </html>

    打印结果:

    <!DOCTYPE html>
    <html>
    <head>
      <title>js两个数组比较去重</title>
    </head>
    <body>
    <script type="text/javascript">
      // 如果追求性能,可以采用空间换时间的做法,在JS中最常见的处理方式就是构建Object,因为Object查找key的时间复杂度是O(1),而数组是O(n)
      const list1 = [
          {id: 0, name: 'xiaomin'},
          {id: 1, name: 'xiaohong'},
      ];
      const list2 = [
          {id: 0, name: 'xiaomin'},
          {id: 1, name: 'xiaohong'},
          {id: 3, name: 'xiaomin'},
          {id: 4, name: 'xiaohong'},
      ];
      // 首先构造Object
      const idSet = list1.reduce((accv=> {
          acc[v.id] = true;
          return acc;
      }, {});
      console.log('构造Object', idSet)
      // 遍历list2,去掉在idSet中存在的id
      const result = list2.filter(v => !idSet[v.id]);
      const repeat = list2.filter(v => idSet[v.id]);
      console.log('去重后的result', result)
      console.log('重复的repeat', repeat)
    </script>
    </body>
    </html>
  • 相关阅读:
    机器学习笔记(二)---- 线性回归
    机器学习笔记(一)----基本概念
    ZZ:SDNLAB技术分享(一):ODL的SFC入门和Demo
    zz:NETCONF协议详解
    技术谈 | SDN 和 NFV 之间的爱与恨
    华为云内容审核—性能更加狂野,价格更加腼腆
    【并发技术01】传统线程技术中创建线程的两种方式
    【开发者portal在线开发插件系列五】命令的响应,即命令结果的上报(mid的使用)
    【并发技术16】线程同步工具Exchanger的使用
    什么是API文档?--斯科特·马文
  • 原文地址:https://www.cnblogs.com/mmzuo-798/p/14666272.html
Copyright © 2011-2022 走看看