题目
给你两个整数数组 nums1 和 nums2 ,请你以数组形式返回两数组的交集。返回结果中每个元素出现的次数,应与元素在两个数组中都出现的次数一致(如果出现次数不一致,则考虑取较小值)。可以不考虑输出结果的顺序。
示例 1:
输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2,2]
示例 2:
输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[4,9]
提示:
1 <= nums1.length, nums2.length <= 1000
0 <= nums1[i], nums2[i] <= 1000
代码
package dayLeetCode;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
public class dayleetcode350 {
public int[] intersect(int[] nums1, int[] nums2) {
List<Integer> list = new ArrayList<>();
List<Integer> ansList = new ArrayList<>();
for (int num : nums1){
list.add(num);
}
for (int num : nums2){
if (list.contains(num) == true){
ansList.add(num);
list.remove(Integer.valueOf(num));
}
}
int[] ans = new int[ansList.size()];
int i = 0;
for (int num : ansList){
ans[i++] = num;
}
return ans;
}
public static void main(String[] args) {
dayleetcode350 obj = new dayleetcode350();
int[] nums = obj.intersect(new int[]{1, 2, 2, 1}, new int[]{2, 2});
for (int num :nums){
System.out.println(num);
}
}
}