集合(set)是一个无序的不重复元素序列。
1.集合的创建:
s = {1,2,3,1,2,3,4,5} #集合创建的一般方法
print(s)
print(type(s))
s1 = {1}
print(type(s1))
s2 = {} #这样创建空集合是不正确的,创建出来是一个字典
print(type(s2))
s3 = set([]) #空集合的创建方法
print(type(s3))
li = [1,2,3,1,2,3]
print(set(li)) #集合转换函数
注意:创建空集合时,不能直接创建,要在小括号内加中括号来表示
2.集合的特性:
集合只支持成员操作符和for循环。
s = {1,2,3}
print(1 in s)
for i in s:
print(i,end='|')
print('\n')
for i,v in enumerate(s):
print('index: %s,value: %s' %(i,v))
print('index: %s,value: %s' %(i,v))
特性测试结果:
3.集合的常用方法:
s = {6,7,8,9}
#增加
s.add(1)
print(s)
s.update({2,3,5})
print(s)
#删除
s.pop()
print(s)
#删除指定元素
s.remove(9)
print(s)
#交集,并集,差集
s1 = {1,2,3}
s2 = {2,3,4}
#并集
print('并集:',s1.union(s2))
print('并集:',s1|s2)
#交集
print('交集:',s1.intersection(s2))
print('交集:',s1&s2)
#差集
print('差集:',s1.difference(s2))
print('差集:',s2.difference(s1))
#对等差分:并集 - 交集
print('对等差分:',s1.symmetric_difference(s2))
print('对等差分:',s2.symmetric_difference(s1))
s3 = {1,2}
s4 = {1,2,3}
print(s4.issuperset(s3))
print(s3.issubset(s4))
#两个集合是否不相交
print(s3.isdisjoint(s4))
结果:
4.集合内置方法完整列表:
#方法 #描述
add() #为集合添加元素
clear() #移除集合中的所有元素
copy() #拷贝一个集合
difference() #返回多个集合的差集
difference_update() #移除集合中的元素,该元素在指定的集合也存在。
discard() #删除集合中指定的元素
intersection() #返回集合的交集
intersection_update() #删除集合中的元素,该元素在指定的集合中不存在。
isdisjoint() #判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。
issubset() #判断指定集合是否为该方法参数集合的子集。
issuperset() #判断该方法的参数集合是否为指定集合的子集
pop() #随机移除元素
remove() #移除指定元素
symmetric_difference() #返回两个集合中不重复的元素集合。
symmetric_difference_update() #移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。
union() #返回两个集合的并集
update() #给集合添加元素
5.集合的综合练习:
华为机测题: 明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性 他先用计算机生成了N个1~1000之间的随机整数(N<=1000),N是用户输>入的,对于 其中重复的数字,只保留一个,把其余相同的数字去掉,不同的数对应着不同的学生的学号,然后再把这些数从小到大排序,按照排好的顺序去找同学做调查,请你协助明明完成 “去重”与排序工作 。
解析:本题中我们利用集合的自动去重,不断的向集合中添加随机整数,遇到相同的随机整数时,集合本身就会自动去重,最后取好数据后,我们利用sorted()函数来排序,即可解决问题:
import random
s=set([])
# N=int(input('请输入N:'))
for i in range(int(input('N:'))):
num=random.randint(1,1000)
s.add(num)
print(s)
print(sorted(s))
print('去重后的元素个数为%d' %len(s))
结果(省略部分数据):