手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaScript中去掉数组中的重复值的实现方法
JavaScript中去掉数组中的重复值的实现方法
摘要:复制代码代码如下:题目:要求写一个函数,去掉给定数组中的重复值。如:传入数组a=[0,8,5,4,78,8,90,4,'a','b','a'...

复制代码 代码如下:

题目:要求写一个函数,去掉给定数组中的重复值。

如:

传入数组 a = [0, 8, 5, 4, 78, 8, 90, 4, 'a', 'b', 'a'];

要求返回:[0,4,5,8,78,90,a,b]

对于这个题目,在面试之后也想了好多次,不过一直没能想出一个时间复杂度较低的方法。昨天下午在宿舍看《JavaScript语言精粹》看到一个书中的一段代码有所触发,于是在jsfiddle上测试了,成功。代码如下(完整版参见jsfiddle)

复制代码 代码如下:

var getNR = function(src) {

src = src || [];

var res = {};

var curr = [];

var i, j = 0,temp, name;

for (i = 0; i < src.length; i++) {

temp = src[i];

if (res[temp]) {

//do noting

} else {

res[temp] = 1;

}

}

for (name in res) {

if (res.hasOwnProperty(name)) {

curr[j++] = name;

}

}

return curr;

};

总结一下我的思路:

思路一:将目标数组进行排序,然后依序删除重复的数组,但这样在删除重复元素的同时也改变数组原有元素的属性,明显是不符合要求的,del。

思路二:新建一个数组b,将a中的元素push到b中,但是在push之前检查该元素是否存在。这个时间复杂度是n*n,最简单也是最笨的办法。

思路三:跟思路二类似,不过充分利用了js对象的属性,新建一个空对象,将a中的元素作为属性添加到该对象中,在添加之前检测该属性是否已存在。全部添加完后将该对象的属性依序放到数组中,return

美团面试的题目中有一道这个题目的变种:

要求在Array类上添加一个方法,对于任意数组调用该方法后,去除该数组中的重复元素。

这个变种题考查的知识点多了些,还包括原型,this的理解等。

【JavaScript中去掉数组中的重复值的实现方法】相关文章:

JavaScript获取并更改input标签name属性的方法

JavaScript中this关键字使用方法详解

javascript用函数实现对象的方法

Javascript 字符串模板的简单实现

javascript函数特点实例

javascript先序遍历DOM树的方法

JavaScript中的私有成员

JavaScript实现点击文字切换登录窗口的方法

JavaScript中数组添加值和访问值常见问题

JavaScript中substring()方法的使用

精品推荐
分类导航