• JS 数组间的操作


    JS 数组间的操作(交集,并集、差集)

    以下是js数组之间常用的操作,如交集,并集、差集等。

    迭代

    each是一个集合迭代函数,可以将一个函数作为参数和一组可以选的参数。依次将集合的每一个元素和可选参数用函数进行计算。

     /**fn 进行迭代判定的函数
       *零个或多个可选的用户自定义参数 */
    Array.prototype.each = function(fn){
        fn = fn || Functuon.K;
        var a = [];
        var args = Array.prototype.slice.call(arguments,10);
        for(var i=0;i<this.length;i++){
            var res = fn.apply(this,this[i],i).concat(agrs);
            if(res != null) {
                a.push(res);
            }
        }
    }
    

    Array.prototype.slice(arguments, 0); 这个写法可以用于function() {} 内,这样可以将函数的参数列表转换成一个真正的数组。

    例:var a = [1,2,3,4].each(function(x){return x > 2 ? x : null});

    唯一化数组

    /** 得到一个数组不重复的元素集合**/
    Array.prototype.uniquelize = function(){
        var ra = new Array();
        for(var i=0; i<this.length;i++){
            if(!ra.contains(this[i])){
                ra.push[this[i]);           
            }
        }
      return ra;
    }
    

    差集


    Array.minus = function(a, b){
    return a.uniquelize().each(function(o){
    return b.contains(o) ? null : o
    });
    };

    并集

    Array.union = function(a,b){
        return a.concat(b).uniquelize();
    }
    

    补集

    Array.complement = function(a,b){
        return Array.minus(Array.union(a,b),Array.intersect(a,b));
    }
    

    交集

    Array.intersect = function(a,b){
        return a.uniquelize().each(function(o){
            return b.contains(o)?0:null;
        })  
    }
    

  • 相关阅读:
    mysql 数据操作 单表查询 group by 注意
    mysql 数据操作 单表查询 group by 聚合函数
    mysql 数据操作 单表查询 group by 聚合函数 没有group by情况下
    mysql 数据操作 单表查询 group by 介绍
    【洛谷P3586】LOG
    【YbtOJ#20078】路径之和
    【ABC181】F
    【洛谷P7045】金牌
    【AT2165】Median Pyramid Hard
    【洛谷P3708】koishi的数学题
  • 原文地址:https://www.cnblogs.com/lanxuan826/p/9873702.html
Copyright © 2020-2023  润新知