Java如何将数组中具有相同的元素都删去
2011-12-02
展开全部
如果是要把List中的重复元素删除的话可以先吧List转成Set去除重复元素
比如现在有个数组为 myArray ,里面有部分的重复元素
Set mySet = new HashSet();
for(Object obj : Array){
mySet.add(obj);
}
mySet中所保存的元素就是唯一的了.
再吧mySet保存到数组中
完整例子:
// 创建一个数组,里面存在重复的元素
String[] myArray = {"s","s","f","d"};
Set<String> mySet = new HashSet<String>();
// 去除重复元素
for(String s : myArray){
mySet.add(s);
}
myArray = new String[mySet.size()];
int index = 0;
// 将去重后的结果存入数组
for(String s : mySet){
myArray[index] = s;
index++;
}
// 打印出来结果
System.out.println(Arrays.toString(myArray));
比如现在有个数组为 myArray ,里面有部分的重复元素
Set mySet = new HashSet();
for(Object obj : Array){
mySet.add(obj);
}
mySet中所保存的元素就是唯一的了.
再吧mySet保存到数组中
完整例子:
// 创建一个数组,里面存在重复的元素
String[] myArray = {"s","s","f","d"};
Set<String> mySet = new HashSet<String>();
// 去除重复元素
for(String s : myArray){
mySet.add(s);
}
myArray = new String[mySet.size()];
int index = 0;
// 将去重后的结果存入数组
for(String s : mySet){
myArray[index] = s;
index++;
}
// 打印出来结果
System.out.println(Arrays.toString(myArray));
展开全部
ArrayList a = new ArrayList(数组);
for(int i = 0 ;i<a.size();i++){
Object obj = 数组[i];
if(a.contains(obj)){
a.remove(i);
}
}
我答案错了,不好意思,当初咋想的忘记了,抱歉。下面的其他匿名网友回答是正确的。另外附上我的修改。
一:利用set的唯一性解决
String[] strArr = {"B","A","C","D","C","A"};
Set<String> strList = new HashSet(Arrays.asList(strArr));
System.out.println(strList.toString());
二:创建新的存储单位,判断是否重复后逐个增加
public static void main(String[] args){
String[] strArr = {"B","A","C","D","C","A"};
List<String> strList = new ArrayList<String>();
for (String str : strArr){
if(strList.contains(str)){
continue;
}
strList.add(str);
}
System.out.println(strList.toString());
}
三:利用steam的distinct方法去重(jdk1.8的新特性)
String[] strArr = {"B","A","C","D","C","A"};
List<String> strList = Arrays.asList(strArr);
strList = strList.stream().distinct().collect(Collectors.toList());
System.out.println(strList.toString());
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用HashSet,将所有的元素放入到hashset里面,再读出来相同的元素就都删除只剩下一个了。
追问
是都删除,不过谢谢了,我已经解决了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
将数组放入set中后在转化到数组就行啦。
追问
我是刚入门的,还有许多方法不知道,只是用最笨的方法解决。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询