集合的定义
#集合里面的元素不可重复
s = {1,1,2,3,3,4,5,6,7,8,8,8}
print(s,type(s))
#定义一个空集合
s1 = {} #默认情况下是dict
print(type(s1))
s2 = set([])
print(type(s2))
#列表的快速去重(先转换为集合,再转换回列表)
li = [1,1,2,3,3,4,5,6,7,8,8,8]
print(list(set(li)))
集合是一个可变的数据类型
添加顺序和存储数据的顺序是不同的
s = {6,7,8,9,2,3,1,4,5}
print(s)
添加
s.add(10)
s.add(0)
print(s)
#增加多个元素
s.update({7,12,13,14})
print(s)
删除
a = s.pop()
print(s)
print(a)
#删除指定元素
s.remove(7)
print(s)
集合的特性
#成员操作符
![s = {1,2,3}
print(1 in s)
print(1 not in s)
for 循环
s1 = {2,3,1}
sorted(s1)
#排序
print(s1)
s2 = {2,3,4}
#并集
print(‘并集:’,s1.union(s2))
print(‘并集:’,s1 | s2)
#交集
print(‘交集:’,s1.intersection(s2))
print(‘交集:’,s1 & s2)
#差集
#s1和s2的差集:s1中有哪些s2中没有的元素
print(‘差集:’,s1.difference(s2))
print(‘差集:’,s1 -s2)
#对等差分:并集- 交集
print(‘对等差分’,s1.symmetric_difference(s2))
print(‘对等差分’,s1 ^ s2)
s1 = {‘redhat’}
s2 = {‘student’}
s3 = {‘redhat’,‘westos’,‘python’}
s4 = {‘redhat’,‘westos’,‘linux’}
#s1是否是s3的子集
print(s3.issubset(s4))
#s2是否是s3的子集
print(s2.issubset(s3))
#两个集合是不是不相交
print(s2.isdisjoint(s3))
print(s3.isdisjoint(s4))
练习
“”"
华为机测题:
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性
他先用计算机生成了N个1~1000之间的随机整数(N<=1000)
,N是用户输入的,对于
其中重复的数字,只保留一个,把其余相同的数字去掉,
不同的数对应着不同的学生的学号,
然后再把这些
数从小到大排序,按照排好的顺序去找同学做调查,
请你协助明明完成“去重”与排序工作
sorted()
“”"
import random
NUM = range(1,1001)
s = set([])
N = int(input(‘输入随机整数:’))
if N > 1000:
print(‘请输入1~1000的整数’)
exit()
else:
for i in range(1,N+1):
a = int(random.choice(NUM))
s.add(a)
print(s)
s1 =sorted(s)
print(s1)