第17章 Python3 集合教程

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

可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

创建格式:


    parame = {value01,value02,...}
    或者
    set(value)


    实例(Python 3.0+) 
     
    >>> basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
    
    >>> print(basket)                      # 这里演示的是去重功能
    
    {'orange', 'banana', 'pear', 'apple'}
    
    >>> 'orange' in basket                 # 快速判断元素是否在集合内
    
    True
    
    >>> 'crabgrass' in basket
    
    False
    >>> # 下面展示两个集合间的运算.
    
    ...
    
    >>> a = set('abracadabra')
    
    >>> b = set('alacazam')
    
    >>> a                                  
    
    {'a', 'r', 'b', 'c', 'd'}
    
    >>> a - b                              # 集合a中包含而集合b中不包含的元素
    
    {'r', 'd', 'b'}
    
    >>> a | b                              # 集合a或b中包含的所有元素
    
    {'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'}
    
    >>> a & b                              # 集合a和b中都包含了的元素
    
    {'a', 'c'}
    
    >>> a ^ b                              # 不同时包含于a和b的元素
    
    {'r', 'd', 'b', 'm', 'z', 'l'}

类似列表推导式,同样集合支持集合推导式(Set comprehension):


    实例(Python 3.0+) 
     
    >>> a = {x for x in 'abracadabra' if x not in 'abc'}
    
    >>> a
    
    {'r', 'd'}


集合的基本操作

1、添加元素

语法格式如下:


    s.add( x )

将元素 x 添加到集合 s 中,如果元素已存在,则不进行任何操作。


    实例(Python 3.0+) 
     
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> thisset.add("Facebook")
    
    >>> print(thisset)
    
    {'Taobao', 'Facebook', 'Google', 'Runoob'}

还有一个方法,也可以添加元素,且参数可以是列表,元组,字典等,语法格式如下:


    s.update( x )

x 可以有多个,用逗号分开。


    实例(Python 3.0+) 
     
    
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> thisset.update({1,3})
    
    >>> print(thisset)
    
    {1, 3, 'Google', 'Taobao', 'Runoob'}
    
    >>> thisset.update([1,4],[5,6])  
    
    >>> print(thisset)
    
    {1, 3, 4, 5, 6, 'Google', 'Taobao', 'Runoob'}
    
    >>>

2、移除元素

语法格式如下:


    s.remove( x )

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


    实例(Python 3.0+) 
     
    
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> thisset.remove("Taobao")
    
    >>> print(thisset)
    
    {'Google', 'Runoob'}
    
    >>> thisset.remove("Facebook")   # 不存在会发生错误
    
    Traceback (most recent call last):
    
      File "<stdin>", line 1, in <module>
    
    KeyError: 'Facebook'
    
    >>>

此外还有一个方法也是移除集合中的元素,且如果元素不存在,不会发生错误。格式请在输出结果查看


    s.discard( x )


    实例(Python 3.0+) 
     
    
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> thisset.discard("Facebook")  # 不存在不会发生错误
    
    >>> print(thisset)
    
    {'Taobao', 'Google', 'Runoob'}

咱们也可以设置随机删除集合中的一个元素,语法格式如下:


    s.pop()


    脚本模式实例(Python 3.0+) 
     
    
    thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
    
    x = thisset.pop()
    
    print(x)
    
     输出结果请在输出结果查看
     
     ```python 
    $ python3 test.py 
    Runoob

多次执行测试结果都不一样。

set 集合的 pop 方法会对集合进行无序的排列,然后将这个无序排列集合的左面第一个元素进行删除。

### 3、计算集合元素个数 ###

**语法格式如下:**

​```python

    len(s)

计算集合 s 元素个数。


    实例(Python 3.0+) 
     
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> len(thisset)
    
    3

4、清空集合

语法格式如下:


    s.clear()

清空集合 s。


    实例(Python 3.0+) 
     
    
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> thisset.clear()
    
    >>> print(thisset)
    
    set()

5、判断元素是否在集合中存在

语法格式如下:


    x in s

判断元素 x 是否在集合 s 中,存在return True,不存在return False。


    实例(Python 3.0+) 
     
    
    >>> thisset = set(("Google", "Runoob", "Taobao"))
    
    >>> "Runoob" in thisset
    
    True
    
    >>> "Facebook" in thisset
    
    False
    
    >>>

集合内置方法完整列表

方法描述
add()为集合添加元素
clear()移除集合中的所有元素
copy()拷贝一个集合
difference()return 多个集合的差集
difference_update()移除集合中的元素,该元素在指定的集合也存在。
discard()删除集合中指定的元素
intersection()return 集合的交集
intersection_update() return 集合的交集。
isdisjoint()判断两个集合是否包含相同的元素,如果没有return True,否则return False。
issubset()判断指定集合是否为该方法参数集合的子集。
issuperset()判断该方法的参数集合是否为指定集合的子集
pop()随机移除元素
remove()移除指定元素
symmetric_difference()return 两个集合中不重复的元素集合。
symmetric_difference_update() 移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。
union()return 两个集合的并集
update()给集合添加元素
## 本专栏所有文章
第1章 Python3 教程第2章 Python3 简介教程
第3章 Python3 环境搭建教程第4章 Python3 VScode教程
第5章 Python3 基础语法教程第6章 Python3 基本数据类型教程
第7章 Python3 数据类型转换教程第8章 Python3 推导式教程
第9章 Python3 解释器教程第10章 Python3 注释教程
第11章 Python3 运算符教程第12章 Python3 数字(Number)教程
第13章 Python3 字符串教程第14章 Python3 列表教程
第15章 Python3 元组教程第16章 Python3 字典教程
第17章 Python3 集合教程第18章 Python3 编程第一步教程
第19章 Python3 条件控制教程第20章 Python3 循环语句教程
第21章 Python3 迭代器与生成器教程第22章 Python3 函数教程
第23章 Python3 数据结构教程第24章 Python3 模块教程
第25章 Python3 输入和输出教程第26章 Python3 File教程
第27章 Python3 OS教程第28章 Python3 错误和异常教程
第29章 Python3 面向对象教程第30章 Python3 命名空间/作用域教程
第31章 Python3 标准库概览教程第32章 Python3 实例教程
第33章 Python 测验教程第34章 Python3 正则表达式教程
第35章 Python3 CGI编程教程第36章 Python3 MySQL(mysql-connector)教程
第37章 Python3 MySQL(PyMySQL)教程第38章 Python3 网络编程教程
第39章 Python3 SMTP发送邮件教程第40章 Python3 多线程教程
第41章 Python3 XML 解析教程第42章 Python3 JSON教程
第43章 Python3 日期和时间教程第44章 Python3 内置函数教程
第45章 Python3 MongoDB教程第46章 Python3 urllib教程
第47章 Python uWSGI 安装配置教程第48章 Python3 pip教程
第49章 Python3 operator教程第50章 Python math教程
第51章 Python requests教程第52章 Python random教程
第53章 Python3 os.replace() 方法教程

寄语

本文有 phlcsdn2023 原创,欢迎点赞、转载,博客地址:https://blog.csdn.net/phlcsdn2023

  • 吹过清风,喝过烈酒,终究,也给了你自由。一月再见,二月你好。
  • 人世间的事就如同是瞎眼老婆婆织出的花边,我们怎么能忍心去毁坏他呢?
  • 美德可以打扮一个人,而财富只有装饰房子。欧洲
  • 母爱如水,母亲是源,无论你奔腾到哪里,身上流淌的,依然有不尽的源头之水。
  • 我们在浩瀚飘渺的宇宙中选择了这个美丽的星球,于是我们来到这个世界,开始了自己的人生。我们掌控着罗盘不失方向的前进,或站在大海面前,或屹立于波涛之巅。在每个转折点,由我们自己选择着命运,选择着永恒的未来。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
青蛙过河问题是一道经典的动态规划问题,可以用Python来解决。该问题的描述是:一只青蛙想要过河,河流被分成了一系列的石头,青蛙可以跳到石头上,但不能跳进水中。给定一个数组stones,表示每个石头的位置,初始时青蛙在第一个石头上,青蛙每次可以跳跃的距离为上一次跳跃的距离加1或减1。要求判断青蛙是否能够到达最后一个石头。 以下是一种解决青蛙过河问题的Python代码示例: ```python def canCross(stones): # 创建一个字典,用于记录每个石头上的跳跃距离 dp = {} for stone in stones: dp[stone] = set() # 初始化第一个石头的跳跃距离为0 dp[stones[0]].add(0) # 遍历每个石头,计算当前石头上的跳跃距离 for stone in stones: for step in dp[stone]: # 遍历当前石头的跳跃距离,计算下一步可能的跳跃距离 for i in range(step - 1, step + 2): if i > 0 and stone + i in dp: dp[stone + i].add(i) # 判断最后一个石头上是否有跳跃距离 return len(dp[stones[-1]]) > 0 # 示例输入 stones = [0, 1, 3, 5, 6, 8, 12, 17] print(canCross(stones)) # 输出:True ``` 该代码使用动态规划的思想,通过一个字典dp来记录每个石头上的跳跃距离。首先初始化第一个石头的跳跃距离为0,然后遍历每个石头,计算当前石头上的跳跃距离。对于每个石头,遍历其跳跃距离,计算下一步可能的跳跃距离,并将其添加到下一个石头的跳跃距离集合中。最后判断最后一个石头上是否有跳跃距离,如果有则返回True,否则返回False。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你得不到的念想

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值