集合的交并差用HashSet实现

面试题:一个集合中的元素为: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);
	
	}
}


  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值