求两个数组中相同的元素

方法一(采用HashSet)

public static Set<Integer> getSameElement(Integer[] a, Integer[] b) {
		Long start = System.currentTimeMillis();
		Set<Integer> temp = new HashSet<Integer>();
		Set<Integer> same = new HashSet<Integer>();
		for (int i = 0; i < a.length; i++) {
			temp.add(a[i]);
		}
		for (int j = 0; j < b.length; j++) {
			if (!temp.add(b[j])) {
				same.add(b[j]);
			}
		}
		System.out.println("HashSet用时:" + (System.currentTimeMillis() - start));
		return same;
}
public static Set<Integer> getSameElement(Integer[] a, Integer[] b) {
		Long start = System.currentTimeMillis();
		Set<Integer> temp = new HashSet<Integer>();
		Set<Integer> same = new HashSet<Integer>();
		Integer[] max = a.length > b.length ? a : b;
		Integer[] min = a.length > b.length ? b : a;
		for (int i = 0; i < max.length; i++) {
			temp.add(max[i]);
		}
		for (int j = 0; j < min.length; j++) {
			if (!temp.add(min[j])) {
				same.add(min[j]);
			}
		}
		System.out.println("HashSet用时:" + (System.currentTimeMillis() - start));
		return same;
}

方法二(采用list)

public static List<Integer> getSamelElement(Integer[] a,Integer[] b){
		
		List<Integer> aList = Arrays.asList(a);
		List<Integer> bList = Arrays.asList(b);
		List<Integer> sameList = new ArrayList<Integer>();
		for(Integer in : aList){
			if(bList.contains(in)){
				sameList.add(in);
			}
		}
		return sameList;
}
public static List<Integer> getSameElement(Integer[] a, Integer[] b) {
		Long start = System.currentTimeMillis();
		List<Integer> aList = new ArrayList<Integer>();
		List<Integer> bList = new ArrayList<Integer>();
		List<Integer> resultList = new ArrayList<Integer>();
		for (int i = 0; i < a.length; i++) {
			aList.add(a[i]);
		}
		for (int j = 0; j < b.length; j++) {
			bList.add(b[j]);
		}
		List<Integer> smallList = a.length > b.length ? bList : aList;
		List<Integer> bigList = a.length > b.length ? aList : bList;
		for (int k = 0; k < smallList.size(); k++) {
			int temp = smallList.get(k);
			if (bigList.contains(temp)) {
				resultList.add(temp);
			}
		}
		System.out.println("List用时:" + (System.currentTimeMillis() - start));
		return resultList;
}

推荐采用方法一

Remark:QQ交流群:260052172

转载于:https://my.oschina.net/Tsher2015/blog/857414

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值