本文實例講述了Python實現兩個list求交集,并集,差集的方法。分享給大家供大家參考,具體如下:
在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: ",retEdef 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相關內容可查看本站專題:《Python列表(list)操作技巧總結》、《Python字符串操作技巧匯總》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
新聞熱點
疑難解答