给定两个数组,编写一个函数来计算它们的交集。
示例1:
输入:nums1 = [1,2,2,1], nums2 = [2,2] 输出:[2,2]
示例2:
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4] 输出:[4,9]
- 说明:
输出结果中每个元素出现的次数,应与元素在两个数组中出现次数的最小值一致。
我们可以不考虑输出结果的顺序。
- 进阶:
如果给定的数组已经排好序呢?你将如何优化你的算法?
如果 nums1 的大小比 nums2 小很多,哪种方法更优?
如果 nums2 的元素存储在磁盘上,内存是有限的,并且你不能一次加载所有的元素到内存中,你该怎么办?
题解分析:
首先,我们可以确定,要是数组本身是有序的,很快就可以得出数组的交集是什么
那么我们就先对数组进行排序。然后通过双指针遍历两个数组
在开始遍历的时候,两个指针都位于初始位置,然后往右移动指针
1、当两个指针的数据不相等时,则较小数据的指针向右移动
2、当两个数据相等时,则添加数据到结果集中,并且将两个指针都向右移动
3、当其中一个指针超出界限时,则遍历结束
class Solution {
public int[] intersect(int[] nums1, int[] nums2) {
Arrays.sort(nums1);
Arrays.sort(nums2);
int length1 = nums1.length, length2 = nums2.length;
int[] intersection = new int[Math.min(length1, length2)];
int index1 = 0, index2 = 0, index = 0;
while (index1 < length1 && index2 < length2) {
if (nums1[index1] < nums2[index2]) {
index1++;
} else if (nums1[index1] > nums2[index2]) {
index2++;
} else {
intersection[index] = nums1[index1];
index1++;
index2++;
index++;
}
}
return Arrays.copyOfRange(intersection, 0, index);
}
}