FuncitonObject

    <!DOCTYPE>
<html>
    <head>
        <meta charset="utf-8">
        <script type="text/javascript">
            // 挑战三,三维数组或 n 维数组去重,使用 arguments 重写
            var arr = [2,3,4,[2,3,[2,3,4,2],5],3,5,[2,3,[2,3,4,2],2],4,3,6,2];
            var unique = function(arr) {
            var result = [];
            (function(arr) {
                var f = arguments.callee;
                console.info("f=",f);
                arr.forEach(function() {
                    if (Array.isArray(arguments[0])) {
                        f(arguments[0]);
                        console.info("f==",arguments[0]);
                    } else {
                        if (result.indexOf(arguments[0]) < 0) {
                            result.push(arguments[0]);
                        }
                    }
                });
            }(arr));
            return result;
        }
        console.log(unique(arr)); // [2,3,4,5,6]




            //一维数组
            /*var arr = [1,1,2,5,6];*/
            /*function unique1 (arr){
                var arrs = [];
                for(var i=0;i<arr.length;i++){
                    //-1表示arr[i]没有出现
                    if(arrs.indexOf(arr[i])==-1){
                        arrs.push(arr[i]);
                    }
                }
                console.log(arrs);
            }
            unique1(arr);*/

            //此方法有个弊端
            /*function unique2(arr){
                var arrs=[];
                var jump={};
                for(var i=0;i<arr.length;i++){
                    if(!jump[arr[i]]){
                        arrs.push(arr[i]);
                        jump[arr[i]]=1;
                    }
                }
                console.log(arrs);
            }
            unique2(arr);*/
        </script>
    </head>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值