zoukankan      html  css  js  c++  java
  • Python 集合

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

    【直接把重复的元素去除,无序,不支持索引】

    可以使用大括号 { } 或者 set() 函数创建集合

    注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典

    创建&相关功能

    >>> xx = set([1,2,3,4])
    >>> print(xx)
    {1, 2, 3, 4}
    >>> yy = set('1234')
    >>> print(yy)
    {'3', '1', '4', '2'}
    >>> zz = {1,2,3,4}
    >>> print(zz)
    {1, 2, 3, 4}
    >>>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'}

    类似列表推导式,同样集合支持集合推导式

    >>>a = {x for x in 'abracadabra' if x not in 'abc'}
    >>> a
    {'r', 'd'}
     >>> b = {x for x in 'abracadabraz' if x not in 'abc'}
    >>> b
    {'d', 'r', 'z'}
     
     
    添加
    
    

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

    s.add( x )

    >>>thisset = set(("Google", "Runoob", "Taobao"))
    >>> thisset.add("Facebook")
    >>> print(thisset)
    {'Taobao', 'Facebook', 'Google', 'Runoob'}
     

    2.也可以添加元素,且参数可以是列表,元组,字典等,语法格式如下:

    s.update( x )

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

    >>>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'

     

    
    
    移除
    s.remove( x )

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

     

    >>>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' 
     
     

    2. 移除集合中的元素,且如果元素不存在,不会发生错误

    s.discard( x )
    >>>thisset = set(("Google", "Runoob", "Taobao"))
    >>> thisset.discard("Facebook") # 不存在不会发生错误
    >>> print(thisset)
    {'Taobao', 'Google', 'Runoob'}

    3. 设置随机删除集合中的一个元素,语法格式如下

    s.pop()
    脚本下:
    thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
    x = thisset.pop() print(x)

    输出结果:

    $ python3 test.py 
    Runoob

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

    然而在交互模式,pop 是删除集合的第一个元素(排序后的集合的第一个元素)

    >>>thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
    >>> thisset.pop() 'Facebook'
    >>> print(thisset)
    {'Google', 'Taobao', 'Runoob'
     
     
    计算
    len(s)

    计算集合 s 元素个数。

    >>>thisset = set(("Google", "Runoob", "Taobao"))
    >>> len(thisset)
    3
     
     
    s.clear()

    清空集合 s。

    >>>thisset = set(("Google", "Runoob", "Taobao"))
    >>> thisset.clear()
    >>> print(thisset)
    set()
     
     
     
    内置方法
  • 相关阅读:
    最大公约数
    九宫格
    Hanoi双塔问题(简单的枚举)
    最高分
    盒子
    CodeForces Round #303 Div. 2
    关于“被密码保护”的文章
    【学习】组合数的递推公式
    [FZYZOJ 1821] 一道果题
    [FZYZOJ 1889] 厨房救济
  • 原文地址:https://www.cnblogs.com/expedition/p/10691902.html
Copyright © 2011-2022 走看看