集合
#集合里面的元素是不可重复的
s = {1,2,3,4,1,2,3,4,[1,2,3,4]}
print(s,type(s))
s={1,2,3,4,1,2,3,4,[1,2,3,4]}
TypeError: unhashable type: 'list'
s={1,2,3,4,1,2,3,4}
print(s,type(s))
{1, 2, 3, 4} <class 'set'>
#定义一个空集合
s2 = {} #默认情况下是dict
print(s2,type(s2))
{} <class 'dict'>
s3 = set([]) #正确定义空集合
print(s3,type(s3))
set() <class 'set'>
#列表去重
li = [1,2,3,1,2,3,4,5,6,4,5,6]
print(list(set(li)))
[1, 2, 3, 4, 5, 6]
集合的特性
集合支持的特性只有:成员操作符
s = {1,2,3}
print(1 in s)
print(1 not in s)
True
False
for i in s:
print(i,end='')
print()
print('~~~~~~~~~~~~')
123
~~~~~~~~~~~~
集合的常用方法
集合是一个可变的数据类型
添加顺序和在集合中存储的顺序不同
s = {6,7,8,9,1,2,3}
print(s)
{1, 2, 3, 6, 7, 8, 9}
#添加
s.add(10)
s.add(0)
print(s)
{0, 1, 2, 3, 6, 7, 8, 9, 10}
#增加多个元素
s.update({3,4,5,6,7,8})
print(s)
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
#删除
s.pop()
s.pop()
s.pop()
print(s)
{3, 4, 5, 6, 7, 8, 9, 10}
#删除指定元素 元素必须要存在
s.remove(3)
print(s)
{4, 5, 6, 7, 8, 9, 10}
s.remove(3)
print(s)
s.remove(3)
KeyError: 3
交集 并集 差集
s1 = {1,2,3}
s2 = {2,3,4}
#并集
print('并集:',s1.union(s2))
print('并集:',s1 | s2)
并集: {1, 2, 3, 4}
#交集
print('交集:',s1.intersection(s2))
print('交集:',s1 & s2)
交集: {2, 3}
#差集
#s1和s2的差集:s1中有哪些元素s2中没有
print('差集:',s1.difference(s2))
print('差集:',s1-s2)
差集: {1}
#s2和s1的差集
print('差集:',s2.difference(s1))
print('差集:',s2-s1)
差集: {4}
#对等差分:并集 - 交集
print('对等差分:',s1.symmetric_difference(s2))
print('对等差分:',s1^s2)
对等差分: {1, 4}
s3 = {'redhat','westos'}
s4 = {'redhat','westos','linux'}
#s3是否s4的子集
print(s3.issubset(s4))
True
#s3是否s4的超集
print(s3.issuperset(s4))
False
#两个集合是不是不相交
print(s3.isdisjoint(s4))
False
—————练习—————
华为机测题:
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性
他先用计算机生成了N个1~1000之间的随机整数(N<=1000)
N是用户输入的,对于其中重复的数字,只保留一个,把其余相同的数字去掉
不同的数对应着不同的学生的学号
然后再把这些数从小到大排序,按照排好的顺序去找同学做调查
请你协助明明完成‘去重’与排序工作
import random
N = int(input('请输入数量:'))
nmb = []
for i in range(N):
nmb.append(random.randint(1, 1000))
set(nmb)
nmb.sort()
print(nmb)
------------------OR--------------------------
import random
s = set([])
for i in range(int(input('N:'))):
s.add(random.randint(1,1000))
print(sorted(s))