Given two arrays, write a function to compute their intersection.
Example 1:
Input: nums1 = [1,2,2,1], nums2 = [2,2] Output: [2]
Example 2:
Input: nums1 = [4,9,5], nums2 = [9,4,9,8,4] Output: [9,4]
Note:
- Each element in the result must be unique.
- The result can be in any order.
给定两个数组,编写一个函数来计算它们的交集。
示例 1:
输入: nums1 = [1,2,2,1], nums2 = [2,2] 输出: [2]
示例 2:
输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4] 输出: [9,4]
说明:
- 输出结果中的每个元素一定是唯一的。
- 我们可以不考虑输出结果的顺序。
JAVA实现思路:直接暴力循环求解的时间复杂度为O(n2),因此考虑缩减时间复杂度为O(nlog2n)。将两个数组排好序,再从头对比是个办法。
class Solution {
public int[] intersection(int[] nums1, int[] nums2) {
Arrays.sort(nums1);
Arrays.sort(nums2);
int len = nums1.length>nums2.length?nums2.length:nums1.length;
int []temp = new int[len];
int k=0;
int i=0,j=0;
while(i<nums1.length && j<nums2.length){
if(nums1[i]==nums2[j]){ //相等就考虑是并集
if(k==0 || temp[k-1]!=nums1[i]){ //解决连续相等情况 比如[1,1,2,2]和[2,2]
temp[k++]=nums1[i];
}
i++;
j++;
}
else if(nums1[i]>nums2[j])
j++;
else
i++;
}
int []res = new int[k];
for(i=0;i<k;i++)
res[i]=temp[i];
return res;
}
}