python_集合

1、集合的定义

  • 集合里面的元素是不可重复的
s = {1,2,3,1,2,3,4,5}
print(s)
print(type(s))
运行结果:
{1, 2, 3, 4, 5}
<class 'set'>
  • 空集合
s2 = {}
print(type(s2))
s3 = set([])
print(s3)
print(type(s3))
运行结果:
<class 'dict'>   ##s2是一个字典,不是集合
set()
<class 'set'>
  • 集合的应用
li = [1,2,3,1,2,3]
print(list(set(li)))  ##去除重复元素后的列表
运行结果:
[1, 2, 3]

2、集合的特性

  • 集合只支持成员操作符和for循环(迭代)
s = {1,2,3,5,7}
print(1 in s)
运行结果:
True
s = {1,2,3,5,7}
for i in s:
    print(i,end='|')
运行结果:
1|2|3|5|7|
for i,v in enumerate(s):
    print('index: %s,value: %s' %(i,v))
运行结果:
index: 0,value: 1
index: 1,value: 2
index: 2,value: 3
index: 3,value: 5
index: 4,value: 7

3、集合常用的方法

  • 集合:无序的数据类型
    添加顺序和在集合中存储的顺序是不一定相同的
  • 增加一个元素
s = {4,5,6,7}
s.add(2)
print(s)
运行结果:
{2, 4, 5, 6, 7}
  • 增加多个元素
s = {4,5,6,7}
s.update({2,9,3})
print(s)
运行结果:
{2, 3, 4, 5, 6, 7, 9}
  • 删除
s = {9,5,6,7}
s.pop()  ##默认删除的是集合的第一个元素
print(s)
运行结果:
{5, 6, 7}
  • 删除指定元素
s = {9,5,6,7}
s.remove(6)
print(s)
运行结果:
{9, 5, 7}
  • 并集
s1 = {1,2,3}
s2 = {2,3,4}
print('并集:',s1.union(s2))  ##.union 和 | 都是表示两者的并集
print('并集:',s1|s2)
运行结果:
并集: {1, 2, 3, 4}
并集: {1, 2, 3, 4}
  • 交集
s1 = {1,2,3}
s2 = {2,3,4}
print('交集:',s1.intersection(s2)) ##intersection和&表示交集
print('交集:',s1&s2)
运行结果:
交集: {2, 3}
交集: {2, 3}
  • 差集:集合减去其本身和另一集合的交集
s1 = {1,2,3}
s2 = {2,3,4}
print('差集:',s1.difference(s2)) ##s1-(s1&s2)
print('差集:',s2.difference(s1)) ##s2-(s1&s2)
运行结果:
差集: {1}
差集: {4}
  • 对等差分:并集 - 交集
print('对等差分:',s2.symmetric_difference(s1))
print('对等差分:',s1^s2)
运行结果:
对等差分: {1, 4}
对等差分: {1, 4}
  • 超集:如果s3中的每一个元素都在集合s4中,且s4中可能包含s3中没有的元素,那么s4就是s3的一个超集
s3 = {1,2}
s4 = {1,2,3}
print(s3.issuperset(s4))  ##s3是s4的超集
print(s4.issuperset(s3))  ##s4是s3的超集

print(s3.issubset(s4))   #s3是否为s4的子集

print(s3.isdisjoint(s4))  #两个集和是不是 不相交
运行结果:
False
True
True
False

4、集合练习(华为机测题)

"""
# _*_coding:utf-8 _*_
Name:集合_03.py
Date:4/2/19
Author:LiMin-wsp
Connect:314690259@qq.com
Desc:
"""
"""
华为机测题:
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性
他先用计算机生成了N个1~1000之间的随机整数(N<=1000),N是用户输入>的,对于
其中重复的数字,只保留一个,把其余相同的数字去掉,不同的数对应着
不同的学生的学号,然后再把这些
数从小到大排序,按照排好的顺序去找同学做调查,请你协助明明完成“>去重”与排序工作
"""
import random
s = set([])   ##先定义一个空集合
N = int(input('输入: '))
for i in range(N):
    s.add(random.randint(1,1000))  ##这N个数都是在1-1000之间的
print(s)    ##将集合打印出,因为集合的元素是非重复
print(sorted(s))   ##将集合按照从小到大排序
运行结果:
输入: 8
{420, 873, 811, 619, 658, 277, 793, 795}
[277, 420, 619, 658, 793, 795, 811, 873]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值