面试题:一个集合中的元素为:a b c d e
另一个集合中的元素:b c d e f
构建一个新的集合,使它们中的元素为: a b c d e f
~~~~ : a f
~~~~ :b c d e
HashSet 集合是无序无重复的,所以在合并两个集合时也不会增加重复的元素.
set.removeAll(set1);//删除set集合中与set1集合中重复的元素。
set.retainAll(set1);//删除set集合中set1集合中不存在的元素,与removeAll()相反
package set集合;
import java.util.HashSet;
public class Test {
public void bingSet(HashSet<String> set1,HashSet<String> set2){
set1.addAll(set2);
for(String s : set1){
System.out.println(s);
}
}
public void chaSet(HashSet<String> set1,HashSet<String> set2){
HashSet<String> set3 = new HashSet<String>();
set3.addAll(set1);
set3.removeAll(set2);
set1.removeAll(set3);
for(String s : set1){
System.out.println(s);
}
}
public void jiaoSet(HashSet<String> set1,HashSet<String> set2){
HashSet<String> set3 = new HashSet<String>();
set3.addAll(set1);
set3.removeAll(set2);
set2.removeAll(set1);
set2.addAll(set3);
for(String s : set2){
System.out.println(s);
}
}
public static void main(String[] args){
HashSet<String> set1 = new HashSet<String>();
set1.add("a");
set1.add("b");
set1.add("c");
set1.add("d");
set1.add("e");
HashSet<String> set2 = new HashSet<String>();
set2.add("b");
set2.add("c");
set2.add("d");
set2.add("e");
set2.add("f");
Test test = new Test();
test.bingSet(set1,set2);
test.chaSet(set1, set2);
test.jiaoSet(set1, set2);
}
}