python创建一个空集合_Python3集合-Python入门到精通

前言

更多内容,请访问我的 个人博客。v2-8186eaa2e9f12d49543feaaaee5e780e.pnghttps://www.zhihu.com/video/1168681020743831552

集合

集合(set)是一个无序、不重复的元素序列。

这里我们来和列表、元组对比一下:列表是一组有序的元素集合。

元组也是一组有序的元素集合,但元素不可修改。

集合的基本操作

创建集合

使用大括号 { } 创建集合。但不能使用 {} 创建一个空集合,因为 {} 创建的是空字典。

>>> student = {'Tom', 'Mary', '潘高'}

>>> student2 = {}

>>> type(student2)

也可以使用 set() 函数创建集合。 直接使用 set() 创建的是空集合,插入字符串、列表、元组等参数就可以创建非空集合。

>>> a = set((1, 2, 3))

>>> a

{1, 2, 3}

>>> a = set([1, 2, 3, 1, 2, 3])

>>> a

{1, 2, 3}

>>> a = set('潘高陪你学编程')

>>> a

{'程', '潘', '你', '编', '学', '高', '陪'}

我们可以看到集合的两个特点:集合会自动将重复元素剔除。

元组、列表是“按顺序”打印出来的,字符串是无序的。所以,集合不一定会原样打印出来,因为集合是无序的。

添加元素s.add(x)

将变量 x 看作一个整体添加到集合 s 中,集合只增加一个数据项。如果元素已存在,则不进行任何操作。

>>> student = {'Tom', 'Mary', '潘高'}

>>> student.add('Lucy')

>>> student

{'潘高', 'Mary', 'Lucy', 'Tom'}s.update(x)

变量 x 可以是列表、元组、字典等,可以是多个变量,用逗号分开。将所有的变量分隔成单个字符插入集合中。

>>> student = {'Tom', 'Mary', '潘高'}

>>> student.update('Lucy', 'XML')

>>> student

{'c', 'y', 'u', '潘高', 'M', 'L', 'X', 'Mary', 'Tom'}

移除元素s.remove(x)

将元素 x 从集合 s 中移除。如果元素不存在,则报错。

>>> student = {'Tom', 'Mary', '潘高'}

>>> student.remove('潘高')

>>> student

{'Mary', 'Tom'}

>>> student = {'Tom', 'Mary', '潘高'}

>>> student.remove('Lucy')

Traceback (most recent call last):

File "", line 1, in

KeyError: 'Lucy's.discard(x)

将元素 x 从集合 s 中移除。即使元素不存在,也并不会报错。

>>> student = {'Tom', 'Mary', '潘高'}

>>> student.discard('Lucy')

>>> student

{'潘高', 'Mary', 'Tom'}s.pop()

删除集合中的一个元素,并返回删除的元素。只当集合元素是字符串类型时,并且在脚本运行(CMD)时才会随机删除,在交互式环境(IDE)中是保持删除左边第一个元素的。如果集合元素是其他数据类型时,是删除左边第一个元素的。如果删除的集合为空,就会报错。

>>> student = {'Tom', 'Mary', '潘高'}

>>> student

{'潘高', 'Mary', 'Tom'}

>>> student.pop()

'潘高'

集合间的运算

>>> s1 = {'Tom', 'Mary', '潘高'}

>>> s2 = {'Tom', 'Lucy'}

>>> s1 - s2

{'潘高', 'Mary'}

>>> s1 | s2

{'Lucy', '潘高', 'Mary', 'Tom'}

>>> s1 & s2

{'Tom'}

>>> s1 ^ s2

{'潘高', 'Mary', 'Lucy'}

更多编程教学请关注公众号:潘高陪你学编程

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 本演示程序中,集合元素限定为数字,大小由用户输入。集合中数字顺序不限,且一旦出现重复字符或非法字符,程序能自动滤去。输出的运算结果中将不含重复数字或非法字符,且按照从小到大的顺序输出。<br>2. 演示程序以用户和计算机的对话方式执行,即在计算机上显示“提示信息”之后,由用户在键盘上输入演示程序中规定的运算命令;相应的数据输入和运算结果显示在其后。<br>3. 程序执行的命令包括:<br>(1)构造集合1;(2)构造集合2;(3)判断某数是否为集合元素;(4)添加元素;(5)删除元素;(6)求并集(存入集合1中);(7)求交集(存入集合3中);(8)输出集合1;(9)输出集合2;(0)退出。<br>“构造集合1”和“构造集合2”时,需以整型数字形式键入集合元素。<br><br>为实现上述程序功能,以线性链表表示集合。为此,需要两个抽象数据类型:线性表和集合。<br>1. 线性表的抽象数据类型定义为:<br> ADT LinkList{<br> 数据对象:D={ | IntSet,i=1,2,…,n,n 0}<br> 数据关系:R1={< , >| , D, < ,i=2,…,n}<br> 基本操作:<br> InitList(*L)<br> 操作结果:构造一个的线性链表L。<br> IsElement(*L,e)<br> 初始条件:线性表L已存在。<br> 操作结果:若e是L的数据元素,返回1,否则返回0。<br> Append(*L,e)<br> 初始条件:线性表已存在。<br> 操作结果:按照由大到小的顺序往线性表里插入元素e,不允许重复元素。<br> Delete(*L,e)<br> 初始条件:线性表已存在。<br> 操作结果:在L中删除元素e。<br> }ADT LinkList<br>2. 集合的抽象数据类型定义为:<br> ADT LinkSet {<br> 数据对象:D={ | IntSet,i=1,2,…,n,n 0}<br> 数据关系:R1={}<br> 基本操作:<br> CreatSet(*L)<br> 初始条件:s为整型数组。<br> 操作结果:生成一个由s中数字构成的集合。<br> Union(*S1,*S2)<br> 初始条件:集合S1和S2存在。<br> 操作结果:生成一个由S1和S2的并集构成的集合,返回到S1。<br> Intersection (*S1,*S2)<br> 初始条件:集合S1和S2存在。<br> 操作结果:生成一个由S1和S2的交集构成的集合,返回到S1。<br> PrintSet (*S)<br> 初始条件:集合S已存在。<br> 操作结果:依次显示集合S中的全部元素。<br> }ADT LinkSet<br><br><br>带菜单<br>Turbo c 3.0编写

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值