Discuz教程网

JavaScript中去掉数组中的重复值的实现方法

[复制链接]
authicon dly 发表于 2011-9-14 08:27:33 | 显示全部楼层 |阅读模式

  1. 题目:要求写一个函数,去掉给定数组中的重复值。
  2. 如:
  3. 传入数组 a = [0, 8, 5, 4, 78, 8, 90, 4, 'a', 'b', 'a'];
  4. 要求返回:[0,4,5,8,78,90,a,b]
复制代码

对于这个题目,在面试之后也想了好多次,不过一直没能想出一个时间复杂度较低的方法。昨天下午在宿舍看《JavaScript语言精粹》看到一个书中的一段代码有所触发,于是在jsfiddle上测试了,成功。代码如下(完整版参见jsfiddle)
  1. var getNR = function(src) {
  2. src = src || [];
  3. var res = {};
  4. var curr = [];
  5. var i, j = 0,temp, name;
  6. for (i = 0; i < src.length; i++) {
  7. temp = src[i];
  8. if (res[temp]) {
  9. //do noting
  10. } else {
  11. res[temp] = 1;
  12. }
  13. }
  14. for (name in res) {
  15. if (res.hasOwnProperty(name)) {
  16. curr[j++] = name;
  17. }
  18. }
  19. return curr;
  20. };
复制代码

总结一下我的思路:
思路一:将目标数组进行排序,然后依序删除重复的数组,但这样在删除重复元素的同时也改变数组原有元素的属性,明显是不符合要求的,del。
思路二:新建一个数组b,将a中的元素push到b中,但是在push之前检查该元素是否存在。这个时间复杂度是n*n,最简单也是最笨的办法。
思路三:跟思路二类似,不过充分利用了js对象的属性,新建一个空对象,将a中的元素作为属性添加到该对象中,在添加之前检测该属性是否已存在。全部添加完后将该对象的属性依序放到数组中,return
美团面试的题目中有一道这个题目的变种:
要求在Array类上添加一个方法,对于任意数组调用该方法后,去除该数组中的重复元素。
这个变种题考查的知识点多了些,还包括原型,this的理解等。



上一篇:jQuery + Flex 通过拖拽方式动态改变图片的代码
下一篇:JavaScript 大数据相加的问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2025-5-2 16:17

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表