添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

项目github地址: bitcarmanlee easy-algorithm-interview-and-practice
经常有同学私信或留言询问相关问题,V号bitcarmanlee。github上star的同学,在我能力与时间允许范围内,尽可能帮大家解答相关问题,一起进步。

在python中,数组可以用list来表示。如果有两个数组,分别要求交集,并集与差集,怎么实现比较方便呢?
当然最容易想到的是对两个数组做循环,即写两个for循环来实现。这种写法大部分同学应该都会,而且也没有太多的技术含量,本博主就不解释了。这里给大家使用更为装bility的一些方法。

老规矩,talk is cheap,show me the code

#!/usr/bin/env python
#coding:utf-8
Created on 2016年6月9日
@author: lei.wang
def diff(listA,listB):
    #求交集的两种方式
    retA = [i for i in listA if i in listB]
    retB = list(set(listA).intersection(set(listB)))
    print "retA is: ",retA
    print "retB is: ",retB
    retC = list(set(listA).union(set(listB)))
    print "retC1 is: ",retC
    #求差集,在B中但不在A中
    retD = list(set(listB).difference(set(listA)))
    print "retD is: ",retD
    retE = [i for i in listB if i not in listA]
    print "retE is: ",retE
def main():
    listA = [1,2,3,4,5]
    listB = [3,4,5,6,7]
    diff(listA,listB)
if __name__ == '__main__':
    main()

让code run起来

retA is:  [3, 4, 5]
retB is:  [3, 4, 5]
retC1 is:  [1, 2, 3, 4, 5, 6, 7]
retD is:  [6, 7]
retE is:  [6, 7]

结合代码来看,大体上是两种思路:
1.使用列表解析式。列表解析式一般来说比循环更快,而且更pythonic显得更牛逼。
2.将list转成set以后,使用set的各种方法去处理。

本文实例讲述了Python两个list差集交集并集的方法。分享给大家供大家参考。具体如下: list就是指两个数组之间的差集,交集,并集了,这个小学数学时就学过的东西,下面就以实例形式对此加以分析。 一.两个list差集 如有下面两个数组: a = [1,2,3] b = [2,3] 想要的结果是[1] 下面记录一下三种实现方式: 1. 正常的方式 复制代码 代码如下:ret = [] for i in a:     if i not in b:         ret.append(i) 2. 浓缩版 复制代码 代码如下:ret = [ i for i in a if i not i if __name__ == '__main__': a_list = [{'a' : 1}, {'b' : 2}, {'c' : 3}, {'d' : 4}, {'e' : 5}] b_list = [{'a' : 1}, {'b' : 2}] ret_list = [] for item in a_list: if item not in b_list: ret_list.append(item) for item in b_list: if item not in a_list: ret_list.append(item) print( b = [0,2,6] c = [-1,2,5,8] r = list(set(a).intersection(b,c)) # 多个list交集:a、b、c同时拥有的元素 print('r -->', r) # 输出r --> [2] 2.并集 """以a、b、c为实验... ① 遍历其中一个列表检查当前遍历的元素是否存在于另外一个列表,如果存在那么将其加入到结果集中 ② 将两个列表转换为set集合,然后使用集合操作符&两个set集合的交集,最后可以使用list列表并集的结果转换为list列表类型 下面是具体的例子: if __name__ == '__main__': # 主要有两种方法两个列表交集 list1 = [1, 2, 3, 4] list2 = [2, 本文实例讲述了Python两个list差集交集并集的方法。分享给大家供大家参考。具体如下:list就是指两个数组之间的差集,交集,并集了,这个小学数学时就学过的东西,下面就以实例形式对此加以分析。一.两个list差集如有下面两个数组:a = [1,2,3]b = [2,3]想要的结果是[1]下面记录一下三种实现方式:1. 正常的方式代码如下:ret = []for i in a:if i ... a = [0,1,2,3,4] b = [3,4,5,6,7,8,9] list(set(a) & set(b)) # 使用 "&" 运算a与b的交集,输出:[3, 4] list(set(a) | set(b)) # 使用 "|" 运算a与b的并集,输出:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] list(set(b) - set(a)) # 使用 "-" 运算a与b的差(补)集: b中有而a中没有的元素,输出: 查阅网上资料,获取python两个list交集并集差集主要有两种不同的方法,具体哪种方法的效率高还未测试。两种方法具体如下:测试用例x=['a', 'c', 'b', 'e', 'd']y=['b','d','x','y','z']方法一ps:方法一主要借助集合的特性,先将列表转换为集合,然后简便的获取交集并集差集,最后再将结果转换为列表即可。x=set(x)y=set(y)1、交集x...