数组去重

1 篇文章 0 订阅
1 篇文章 0 订阅

数组去重的几种方法,自己瞎总结一下子,其实好多都是相同的思路,随便记录一下

    var a = [1, 3, 3, 9, 1, 4];
第一种 思路:新建一个空数组b,然后循环a, 内部嵌套b的循环,比较b内,是否有a[i]这个值,没有的话,就将a[i]推入b;有就不推
            var b = [];
            for (var i = 0; i < a.length; i++) {
                var flag = true;
                for (var j = 0; j < b.length; j++) {
                    if (b[j] == a[i]) {
                        flag = false;
                        break;
                    }
                }
                if (flag) {
                    b.push(a[i]);
                }
            }
第二种 思路:第一种思路的优化版本,不用设置一个开关变量flag,判断b能正常循环到最后一位,就说明b内没有a[i]
            var b = [];
            for (var i = 0; i < a.length; i++) {
                for (var j = 0; j <b.length; j++) {
                    if (b[j] == a[i]) {
                        break;
                    }
                }
                if (j== b.length) {
                    b.push(a[i]);
                }  
            }
第三种 思路:和第一种思路同理,只不过变换了一下跳出循环的方式,从break变成了return
            var b = [];

            for (var i = 0; i < a.length; i++) {
                function abc() {
                    for (var j = 0; j < b.length; j++) {
                        if (b[j] == a[i]) {
                            return false;
                        }
                    }
                    return true;
                }
                if (abc()) {
                    b.push(a[i]);
                }
            }
第四种 思路:拿a数组的每一项,和这一项后面的数据比较,如果相同的话,就不push进b数组
            var b = [];
            for (var i=0;i<a.length;i++){
                var flag = true;
                for(var j = i+1;j<a.length;j++){
                    if(a[i]==a[j]){
                        flag = false;
                        break;
                    }
                }
                if(flag){
                    b.push(a[i]);
                }
            }
第五种 思路: 第四种方法的优化,当a中第i项与后面数据有相同情况,就跳过第i项,然后去i+1项;j取值++i后马上又执行for循环里的j++操作
            var b = [];
            for (var i=0;i<a.length;i++){
                for(var j = i+1;j<a.length;j++){
                    if(a[i]==a[j]){
                        j = ++i;
                    }
                }
                b.push(a[i]);
            }
第六种 思路:拿a里的每一个数据和后面所有项比较,有相同的,就删除当前项,不用再重新声明一个空数组
            for (var i=0;i<a.length;i++){
                for(var j = i+1;j<a.length;j++){
                    if(a[i]==a[j]){
                        a.splice(i,1);
                        --i;
                        j = i+1;
                    }
                }
            }
第七种 思路:和第六种相同,但是如果检查到相同项,第六种是删除前面的,这种是删除后面的
            for (var i=0;i<a.length;i++){ 
                for(var j = i+1;j<a.length;j++){
                    if(a[i]==a[j]){
                        a.splice(j,1);
                        --j;
                    }
                }
            }
第八种 思路:利用对象不能有相同属性名的前提,去筛选出相同项,只用循环一次,前面都是循环两次
            var obj = new Object();
            var b = [];
            for(var i=0;i<a.length;i++){
                if(!obj[a[i]]){
                    obj[a[i]] = true;
                    b.push(a[i]);
                }
            }
第九种 思路:第八种的拓展思路,不用再声明一个b数组,检测到相同项,自动删除,然后记得i–,要么会有遗漏项
            var obj = new Object();
            for(var i=0;i<a.length;i++){
                if(!obj[a[i]]){
                    obj[a[i]] = true;
                }else{
                    a.splice(i,1);
                    i--;
                }
            }
第十种 思路:ES6的新函数,Set传入数组,默认不能有相同项
            var set = new Set(a); 
            var b = Array.from(set);
            //可简化为: 
            var b= Array.from(new Set(a));
第十一种 思路:
未完待续。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值