js数组和字符串去重复几种方法

js数组和字符串去重复几种方法,第1张

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

方法一:

//将数组转换成字符串,遍历数组,移除一个元素後若还能找到该元素,那么这个元素就是重复的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("111","22","33","111")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}

以上是简单类型数据数组的重复校验方法,若数组的元素为对象,处理方式就需要变化一下,取关键属性作为依据

首先,我看到这个问题中描述是“如何删除两个数组中相同的元素”,虽然那个人写了一大堆,竟然用的是array_unique(),从分析到给出的demo一直在解决如何删除“一个”数组中“重复”的元素。汗!答非所问的答案竟然会被采纳。

这里,简单分析一下提问者的真实意图,分以下2种情况:

1.现在有2个一维数组, $arr1和$arr2,现在要删除 $arr1 中存在于 $arr2 的元素。

解决方案:使用array_diff对比返回在 array1 中但是不在 array2 及任何其它参数数组中的值,代码如下:

<?php

$arr1 = array(1, 2, 3, 4)

$arr2 = array(2, 4)

//这一句即可

$arr1 = array_diff($arr1,$arr2)

var_dump($arr1)

2.先声明一下,我看了lt318025大神给出的答案,他的思维非常活跃,已经分了2种情况。

现在有2个一维数组,$a和$b,即删除$a中存在于$b的元素,删除$b中$a存在的元素,组后合并返回。

可是lt318025大神用的PHP版本太高,给出的demo在低版本PHP下运行失败,这里修正一下:

<?php

$a=array(1,2,3)

$b=array(2,3,4)

//得到存在于$a但不存在于$b中的元素组成的数组

$c=array_diff($a,$b)

//这里简单求出在$a但不在$b中的元素

var_dump($c)

//得到存在于$a但不存在于$b中的元素组成的数组与存在于$b但不存在于$a中的元素组成的数组的并集

$d=array_merge(array_diff($a,$b),array_diff($b,$a))

//这里彻底剔除了同时存在于$a和$b中的元素

var_dump($d)

究竟是哪一种情况,这需要看提问者的需求了。

import java.util.*

class BaiDu

{

public static void main(String[] args)

{

TreeSet<String>tr = new TreeSet<String>()

String[] s ={"11","22","22","33","33","33"}

System.out.print("====处理前=======")

for(int i=0i<s.lengthi++){

System.out.print(s[i]+" ")

tr.add(s[i])

}

String[] s2= new String[tr.size()]

System.out.println("=====处理后======")

for(int i=0i<s2.lengthi++){

s2[i]=tr.pollFirst()//从TreeSet中取出元素重新赋给数组

System.out.print(s2[i]+" ")

}

}

}


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

原文地址: http://outofmemory.cn/sjk/6471890.html

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

发表评论

登录后才能评论

评论列表(0条)

保存