如何判断JavaScript 数组含有重复值

如何判断JavaScript 数组含有重复值,第1张

Javascript判断一个数组中是否有重复值的三种方法

判断重复方法一,转为字符串 进行比较:

var ary = new Array("aaa","cc","dd","aaa")

var s = ary.join(",")+","

for(var i=0i<ary.lengthi++) {

if(s.replace(ary[i]+",","").indexOf(ary[i]+",")>-1) {

alert("数组中有重复元素:" + ary[i])

break

}

}

判断重复方法二,数组排序,再比较相邻的值:

var ary = new Array("bbb","cc","dd","bbb")

var nary=ary.sort()

for(var i=0i<ary.lengthi++){

if (nary[i]==nary[i+1]){

alert("数组重复内容为:"+nary[i])

}

}

判断重复方法三,自定义函数方法判断重复:

function isRepeat(arr){

var hash = {}

for(var i in arr) {

if(hash[arr[i]])

return true

hash[arr[i]] = true

}

return false

}

方法一

无需思考,我们可以得到 O(n^2) 复杂度的解法。定义一个变量数组 res 保存结果,遍历需要去重的数组,如果该元素已经存在在 res 中了,则说明是重复的元素,如果没有,则放入 res 中。

function unique(a) {

var res = []

for (var i = 0, len = a.lengthi <leni++) {

var item = a[i]

for (var j = 0, jLen = res.lengthj <jLenj++) {

if (res[j] === item)

break

}

if (j === jLen)

res.push(item)

}

return res

}

var a = [1, 1, '1', '2', 1]

var ans = unique(a)

console.log(ans)// =>[1, "1", "2"]

代码非常简单,那么是否能更简洁些?如果不考虑浏览器兼容,我们可以用 ES5 提供的 Array.prototype.indexOf 方法来简化代码。

function unique(a) {

var res = []

for (var i = 0, len = a.lengthi <leni++) {

var item = a[i]

(res.indexOf(item) === -1) &&res.push(item)

}

return res

}

var a = [1, 1, '1', '2', 1]

var ans = unique(a)

console.log(ans)// =>[1, "1", "2"]

既然用了 indexOf,那么不妨再加上 filter。

function unique(a) {

var res = a.filter(function(item, index, array) {

return array.indexOf(item) === index

})

return res

}

var a = [1, 1, '1', '2', 1]

var ans = unique(a)

console.log(ans)// =>[1, "1", "2"]


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9933116.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存