删除数组条目中重复的条目(可能有多个)返回值是一个仅包含被删除的重复条目的新数组

2016-02-19 09:09 12 1 收藏

下面图老师小编要向大家介绍下删除数组条目中重复的条目(可能有多个)返回值是一个仅包含被删除的重复条目的新数组,看起来复杂实则是简单的,掌握好技巧就OK,喜欢就赶紧收藏起来吧!

【 tulaoshi.com - Web开发 】

今日在bluediea看到淘宝在线招聘,相信淘宝的技术还是很牛的,于是赶紧打开看看题目并试着做做。
到了第三题时卡了偶老半天,并不是做不出来,感觉有很简便的方法但自己就是一时想不出来,不过费了九牛二虎之力终于完成本题,给出了一个另自己还比较满意的答案,欢迎各位朋友指点!

题目如下:
请给Array本地对象增加一个原型方法,它的用途是删除数组条目中重复的条目(可能有多个),返回值是一个仅包含被删除的重复条目的新数组。

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
代码如下:

Array.prototype.delRepeat=function() 
  { 
        var tmpArr=[],rs=[],i,val; 
        for(i=this.length;i0;i--) 
    { 
            val = this[i-1]; 
      if(!tmpArr[val]) 
      { 
                tmpArr[val]=1; 
            }else 
      { 
                rs.push(val); 
          this.splice(i-1,1); 
            } 
        } 
    tmpArr = null; 
        return rs; 
    } 

两个优点:
1、预先将this[i-1]保存在变量val中,减少访问次数。
2、使用array.push方法,替换用变量保存数组长度的办法。

很好!赞一个!
偶还顺便实现了对返回重复项的过滤,可能是对题意理解有偏差。

来源:http://www.tulaoshi.com/n/20160219/1589766.html

延伸阅读
标签: Web开发
在工作中碰到这么一个问题:给定一个已经排序的数组(升序),删除数组中重复的数据,但是只能使用一个数组,这个数组的大小可以变化. 例子:  数组:[1,1,2,2,3,3,4,5,7,10]       输出::[1,2,3,4,5,7,10] 实现(1): var arr =new Array(1,1,2,2,3,3,4,5,7,10); var len = ...
标签: SQLServer
  select distinct * into #table_name from table_name delete from table_name select * into table_name from #table_name drop table #table_name 与此相关的是“select into”选项,可以在数据库属性 对话框中,勾起来此项,或者在Query Analyzer中执行 execute sp_dboption 'db_name','select into','true' 开启。默认值是关闭的。...
标签: 电脑入门
当Excel数据透视表的源数据发生变动后,通常需要对数据透视表进行刷新操作,以将变动后的数据更新到数据透视表中。但是,有些在源数据中已经消失的数据项,却还残留在行字段或列字段的下拉筛选列表中。 要清除这些Excel数据透视表垃圾条目,除了常用的手动删除再恢复字段的方法,还可通过设置让数据透视表实现自动清除。方法如下。 选中数据...
正在看的ORACLE教程是:oracle快速删除重复的记录。做项目的时候,一位同事导数据的时候,不小心把一个表中的数据全都搞重了,也就是说,这个表里所有的记录都有一条重复的。这个表的数据是千万级的,而且是生产系统。也就是说,不能把所有的记录都删除,而且必须快速的把重复记录删掉。 对此,总结了一下删除重复记录的方法,以及每种方法的优...
Foxmail如何删除重复邮件   点击Foxmail主界面工具-查找重复邮件,将对当前选中的邮件列表进行查重,并将重复的邮件列在对话框内,可自由选择并执行删除操作。

经验教程

358

收藏

28
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部