leet-code/src/main/java/leetcode/editor/cn/IntersectionOfTwoArrays.java

60 lines
1.4 KiB
Java
Raw Normal View History

2021-08-23 14:05:33 +08:00
//给定两个数组,编写一个函数来计算它们的交集。
//
//
//
// 示例 1
//
// 输入nums1 = [1,2,2,1], nums2 = [2,2]
//输出:[2]
//
//
// 示例 2
//
// 输入nums1 = [4,9,5], nums2 = [9,4,9,8,4]
//输出:[9,4]
//
//
//
// 说明:
//
//
// 输出结果中的每个元素一定是唯一的。
// 我们可以不考虑输出结果的顺序。
//
// Related Topics 数组 哈希表 双指针 二分查找 排序 👍 406 👎 0
package leetcode.editor.cn;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
//349:两个数组的交集
class IntersectionOfTwoArrays {
public static void main(String[] args) {
//测试代码
Solution solution = new IntersectionOfTwoArrays().new Solution();
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public int[] intersection(int[] nums1, int[] nums2) {
Set<Integer> set = new HashSet<>();
for (int num : nums1) {
set.add(num);
}
int index = 0;
for (int num : nums2) {
if (set.contains(num)) {
set.remove(num);
nums1[index] = num;
index++;
}
}
return Arrays.copyOf(nums1, index);
}
}
//leetcode submit region end(Prohibit modification and deletion)
}