方法一:
//将数组转换成字符串,遍历数组,移除一个元素後若还能找到该元素,那么这个元素就是重复的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]+" ")
}
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)