快速求两个数组交集算法

  快速求出两个数组的交集的算法,如果用循环遍历的方法,其时间复杂度为O(N^N),在面试中一般不考虑这种方法。

  这里提供一种快速算法,算法实现步骤如下:

  1. 找到arr1的最大数max,创建一个max+1大小的数组result。

  2. 以arr1中的值作为result的下标,该索引处的值+1。

  3. 在result数组中遍历arr2中的值为下标处的值,如果该索引值不为0,则代表该值是两者的交集,保留。

  程序实现如下:

	/**
	 * 求两个数组的交集
	 * @param arr1
	 * @param arr2
	 * @return	数组交集
	 */
	private static int[] intersection(int[] arr1,int[] arr2){
		
		int[] result = null;
		
		ArrayList<Integer> list = new ArrayList<>();
		Arrays.sort(arr1);
		result = new int[arr1[arr1.length-1]+1];
		for (int i = 0; i < arr1.length; i++) {
			result[arr1[i]]++;
		}
		for (int i = 0; i < arr2.length; i++) {
			if (arr2[i]<=result.length&&result[arr2[i]]!=0) {
				list.add(arr2[i]);
			}
		}
		
        int[] returnarr = new int[list.size()];
        for (int i = 0; i < list.size(); i++) {
			returnarr[i] = list.get(i);
		}
		return returnarr;
		
	}

  

转载于:https://www.cnblogs.com/centor/p/5649304.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值