Python之集合的特性及常用方法

集合

#集合里面的元素是不可重复的

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))
    原文作者:若无其事的苹果
    原文地址: https://blog.csdn.net/qq_36016375/article/details/90649453
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞