Python入門之集合

                                    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'>
相關文章
相關標籤/搜索