349. Intersection of Two Arrays(求两个数组的交集)

题目

题目很简单,求两个数列的交集。
在这里插入图片描述

一句话代码(效率很低)

将两个集合转换成set,求交集就完事了。(& 或 intersection)

	return list(set(nums1)&(set(nums2)))

优秀代码(效率挺高)

class Solution(object):
    def intersection(self, nums1, nums2): #求交集
        """
        :type nums1: List[int]
        :type nums2: List[int]
        :rtype: List[int]
        """
        num1_hash = {} # 哈希表
        intersect = [] # 交集
      #iterate through first list and hash values
        for i in nums1: # 对于num1中的值,全部加入到哈希表中。
            num1_hash[i]=False
        for i in nums2:
            #if value is in both lists and we haven't checked it yet
            if i in num1_hash and num1_hash[i] == False:
                  #add to our intersection
                intersect.append(i)			# 取出来加入到交集中
                  #mark the value so we don't add duplicates to our intersection
                num1_hash[i]=True  #说明已经被取出了
        return intersect
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值