Python入門之集合
python
1、什麼是集合數據結構
除了列表,元組和字典,集合也是Python語言提供的內置數據結構之一,能夠把集合看做是沒有存儲value的字典,所以集合的特色以下:ide
1. 集合中不能夠存儲重複的數據;函數
2. 集合中的數據是無序的;spa
3. 集合中的數據能夠是任何不可變類型,多種類型的數據能夠混合存儲在一個集合中;內存
4. 集合能夠根據須要動態的伸縮,也就是說,系統會根據須要動態的分配和回收內存,所以在使用前無須預先聲明集合的容量;rem
5. 集合會浪費較大的內存,與列表相比是用空間換取了時間;
字符串
2、集合的建立數學
一、使用花括號{}建立集合it
s = {3,5,8,1,2} print(s) # {1, 2, 3, 5, 8} s = {3,3,6,8,8,9} print(s) # {8, 9, 3, 6} s = {} print(type(s)) # <class 'dict'> 不能使用{}建立空集合,建立的爲字典
二、使用內置函數set建立集合
s = set(range(1,6)) # {1, 2, 3, 4, 5} s = set([3,5,8,1,2]) # {1, 2, 3, 5, 8},能夠傳入列表 s = set((3,5,8,1,2)) # {1, 2, 3, 5, 8},能夠傳入元組 s = set({3,5,8,1,2}) # {1, 2, 3, 5, 8},能夠傳入{}集合 s = set('35812') # {'5', '8', '3', '2', '1'},傳入的字符串會被分隔開 s = set() # set() <class 'set'> 建立空集合
3、集合的增刪查
一、查操做
使用"in" "not in"對列表進行查操做
s1 = {'a','b','c'} print('a' in s1) # True print('d' not in s1) # True
二、增操做
使用add和update方法添加元素
s1 = {'a','b','c'} s1.add('d') # 一次添加一個元素 s1.update('e','f','g') # 一次添加多個元素 print(s1) # {'g', 'f', 'd', 'b', 'c', 'a', 'e'}
三、刪操做
使用pop,remove,discard,clear對集合作刪操做
s1 = {1,2,3,4,5} print(s1.pop()) # 1 一次隨機刪除一個元素 s1.remove(3) # 刪除元素3 print(s1) # {2, 4, 5} s1.discard(2) # 刪除元素2 print(s1) # {4, 5} s1.clear() # 清空集合 print(s1) # set()
4、集合之間的關係
一、兩個集合是否相等,可使用運算符== 和 != 進行判斷
s1 = set([1,2,3,4]) s2 = set([2,3,4,5]) print(s1 == s2) # False print(s1 != s2) # True
二、一個集合是不是另外一個集合的子集
# 調用方法issbubset進行判斷 s1 = {1,2,3,4} s2 = {3,4,6} s3 = {1,2,3,4,5} print(s1.issubset(s3)) # True print(s2.issubset(s3)) # False
三、一個集合是不是另外一個集合的超集
# 能夠調用方法issuperset進行判斷 print(s3.issuperset(s1)) # True print(s3.issuperset(s2)) # False
四、兩個集合是否沒有交集
# 能夠調用方法isdisjiont進行判斷 s1 = {1,3,5,7} s2 = {22,11,44} s3 = {1,2,3,5,7,8} print(s1.isdisjoint(s2)) # True print(s1.isdisjoint(s3)) # False
5、集合的數學操做
一、兩個集合的交集
#s1和s2的交集 #使用intersection方法,返回的是二者的交集 #使用s1.intersection_update(s2)方法,返回值是none,可是會把交集的值賦給s1 s1 = {1,2,3,4} s2 = {3,4} print(s1.intersection(s2)) #{3, 4} print(s1 & s2 ) #{3, 4} print(s1.intersection_update(s2)) #None print(s1) #{3, 4}
二、兩個集合的並集
並集並集,合併的集合,使用union s1 = {1,2,3,4,5} s2 = {3,4,5} print(s1.union(s2)) #{1, 2, 3, 4, 5} print(s1 | s2 ) #{1, 2, 3, 4, 5}
三、兩個集合的差集
#既找到s1在s2中沒有的元素 #使用difference()方法,找到差集 #使用s1.difference_update(s2)方法,返回的值爲None,做用爲將差集賦值給s1 s1 = {1,2,3,4,5,6} s2 = {1,7,9,4,10} print(s1 - s2 ) #{2,3,5,6} print(s1.difference(s2)) #{2,3,5,6} print(s1.difference_update(s2)) #None print(s1) #{2, 3, 5, 6}
四、兩個集合的對稱差集
對稱差集,既去掉兩個集合交集的部分 s1 = {1,3,5,7,9} s2 = {2,3,6,7,10} print(s1 ^ s2 ) #{1, 2, 5, 6, 9, 10} print(s1.symmetric_difference(s2)) #{1, 2, 5, 6, 9, 10} print(s1.symmetric_difference_update(s2)) #None print(s1) #{1, 2, 5, 6, 9, 10}
6、frozenset不可變的集合
frozenset,被凍結的set,也是不可變的set,frozenset置於set就比如tuple置於list
frozenset是不可變類型,存在如下特色:
● 存在哈希值
● 能夠做爲字典的key
● 能夠做爲set的元素
#能夠調用內置函數frozenset建立 print(frozenset(range(6))) # frozenset({0, 1, 2, 3, 4, 5}) print(frozenset([1,2,5,7])) # frozenset({1, 2, 5, 7}) print(frozenset(('a','b','c'))) # frozenset({'a', 'c', 'b'}) print(frozenset('abcdef')) # frozenset({'c', 'f', 'e', 'a', 'b', 'd'}) #做爲set的元素 s1 = set(frozenset([1,2,3,4,56,7,8])) print(s1,type(s1)) # {1, 2, 3, 4, 7, 8, 56} <class 'set'> s1.add(('abc')) print(s1,type(s1)) {1, 2, 3, 4, 'abc', 7, 8, 56} <class 'set'>