博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【数据结构和算法】【刷题】Day1 349. 两个数组的交集(排序,简单,python3)
阅读量:4099 次
发布时间:2019-05-25

本文共 1988 字,大约阅读时间需要 6 分钟。

1.题目:

给定两个数组,编写一个函数来计算它们的交集。

示例 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

------------------------------------------------------------------------------------------------------

2.解题

2.1

结合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 set集合操作
数学符号 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)

------------------------------------------------------------------------------------------------------

2.2 

该题目的分类是排序,但是以上做法似乎与排序没有关系。

引用一下其他人的解法:

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/

你可能感兴趣的文章
Android中的Binder(二)
查看>>
Framework之View的工作原理(一)
查看>>
Web应用架构
查看>>
设计模式之策略模式
查看>>
深究Java中的RMI底层原理
查看>>
用idea创建一个maven web项目
查看>>
Kafka
查看>>
9.1 为我们的角色划分权限
查看>>
维吉尼亚之加解密及破解
查看>>
DES加解密
查看>>
TCP/IP协议三次握手与四次握手流程解析
查看>>
PHP 扩展开发 : 编写一个hello world !
查看>>
inet_ntoa、 inet_aton、inet_addr
查看>>
用模板写单链表
查看>>
用模板写单链表
查看>>
链表各类操作详解
查看>>
C++实现 简单 单链表
查看>>
数据结构之单链表——C++模板类实现
查看>>
Linux的SOCKET编程 简单演示
查看>>
正则匹配函数
查看>>