本文共 1988 字,大约阅读时间需要 6 分钟。
给定两个数组,编写一个函数来计算它们的交集。
示例 1:
输入: nums1 = [1,2,2,1], nums2 = [2,2]
输出: [2] 示例 2:输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出: [9,4] 说明:输出结果中的每个元素一定是唯一的。
我们可以不考虑输出结果的顺序。来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/intersection-of-two-arrays------------------------------------------------------------------------------------------------------
结合b站上 Michelle小姐姐的思路,
这道题目中先将nums1创建集合,提取其唯一的元素,再遍历nums2,判断nums2中的元素是否在nums1的集合中,若有,即有重复元素,在ans列表上加入这个元素,再在nums1的集合中删除这个元素,因为题目要求结果的元素是唯一的。
代码如下:
class Solution: def intersection(self, nums1: List[int], nums2: List[int]) -> List[int]: ans = [] num1 = set(nums1) for i in nums2: if i in num1: ans.append(i) num1.remove(i) return ans
并没有对原视频代码优化,只是结合目前本人的理解简单修改。用到了我不太熟悉的set,set中的元素是没有重复的,无序的
形如a={'a','b','c','d'}。
创建集合:a={'a','b','c','d'}或 a=set('abcd')
增加元素: add(),删除元素remove()
数学符号 | Python符号 | 含义 |
- 或\ | - | 差集,相对补集 |
∩ | & | 交集 |
∪ | | | 并集 |
≠ | != | 不等于 |
= | == | 等于 |
∈ | in | 是成员关系 |
∉ | not in | 非成员关系 |
根据集合求交集的操作&,可以有如下做法,不过时间和空间都没有优化。
class Solution: def intersection(self, nums1: List[int], nums2: List[int]) -> List[int]: num1 = set(nums1) num2 = set(nums2) return list(num1 & num2)
------------------------------------------------------------------------------------------------------
该题目的分类是排序,但是以上做法似乎与排序没有关系。
引用一下其他人的解法:
class Solution: def intersection(self, nums1: List[int], nums2: List[int]) -> List[int]: if not nums1 or not nums2: return [] nums1.sort() nums2.sort() len1 = len(nums1) len2 = len(nums2) result = [] while nums1 and nums2: if nums1[0] == nums2[0]: if not nums1[0] in result: result.append(nums1[0]) nums1.pop(0) nums2.pop(0) elif nums1[0]>nums2[0]: nums2.pop(0) elif nums1[0] < nums2[0]: nums1.pop(0) return result
转载地址:http://yerii.baihongyu.com/