zoukankan      html  css  js  c++  java
  • python基础之集合

    一、python中集合的定义

    由不同元素的集合,集合是一组无序排列的可Hash值,可以作为字典的key特性,集合中的元素是不可变类型。***注意三点(1.不同元素的集合,2.无序排列,3.集合中的元素是不可变类型)

    二、集合的创建

    s = set()
    s = {1,2,3,4,5}

    *注:创建空集合时,只能用set(),如果用第二种方法s={},创建的实际上是一个空字典。
    s = {}
    print(type(s))
    <class 'dict'>

    三、集合的功能

    • 基本功能

    添加(add, update)

    s={1,2,3,5,6}
    s.add(4)              # 只能更新一个值,加的值不能重复
    print(s)
    s.update('4','7')   # 可更新多个值
    print(s)
    执行结果如下:
    {1,2,3,4,5,6}
    {1,2,3,5,6,'4','7'}

    清空(clear)

    s={1,2,3,5,6}
    s.clear()
    print(s)
    执行结果如下:
    set()

    复制

    s={1,2,3,5,6}
    s1=s.copy()
    print(s1)

    执行结果如下:

    s1={1,2,3,5,6}

     删除(pop, remove, discard)

    s={4,10,5,7,8,4,9,2,5,‘s’}

    s.pop() # 因为集合是无序的,所以随机删除的
    print(s)

    执行结果如下:

    s={4, 5, 7, 8, 9, 10, 's'}

     

    s.remove(7)  #删除指定元素3,元素不存在是报错

    执行结果如下:

     s={4,10,5,8,4,9,2,5,‘s’}

    s.discard('hello')  #元素不存在时不报错

    • 特有功能

    交集(intersection 或' &')

    p_s=['lcg','lzq','czd','cyz'] 
    l_s=['cyz','zwx','wxj','czd']
    print(p_s.intersection(l_s))  #求交集 
    print(p_s & l_s)

    执行结果如下:
    {'cyz', 'czd'}
    {'cyz', 'czd'}

    并集(union  或 ' |')

    p_s=['lcg','lzq','czd','cyz']
    l_s=['cyz','zwx','wxj','czd']

    print(p_s.union(l_s))    #求并集

    print(p_s|l_s)

    执行结果如下:

    {'lzq', 'lcg', 'zwx', 'wxj', 'czd', 'cyz'}

    {'lzq', 'lcg', 'zwx', 'wxj', 'czd', 'cyz'}

    差集(difference 或  '-')

    p_s=['lcg','lzq','czd','cyz']
    l_s=['cyz','zwx','wxj','czd']

    print('差集',p_s.difference(l_s))     # 求差集,p_s减去l_s

    print('差集',p_s-l_s)

    执行结果如下:

    差集 {'lzq', 'lcg'}

    差集 {'lzq', 'lcg'}

    交叉补集(symmetric.difference 或 '^')

      p_s=['lcg','lzq','czd','cyz']
      l_s=['cyz','zwx','wxj','czd']
         

    print(p_s.symmetric_difference(l_s))      #交叉补集

    print('交叉补集',p_s^l_s)                        #两个集合合到一起减去他们的交集

    执行结果如下:

    {'zwx', 'wxj', 'lzq', 'lcg'}

    交叉补集 {'zwx', 'wxj', 'lzq', 'lcg'}

    判断是否为有效集(isdisjoint)

           s.isdisjoint:有交集为False,无交集为True    (其中s为集合)

    子集和父集(issubset   和  issuperset)

           s1.issubset(s2):s2是s1的子集

           s2.issuperset(s1): s2是s1的父集

  • 相关阅读:
    初始ASP.NET数据控件【续 DataList】
    初始ASP.NET数据控件GridView
    初始ADO.NET数据操作
    初识 Asp.Net数据验证控件
    【Socket编程】Java通信是这样炼成的
    JAVA之I/O 输入输出流详解
    浅入深出之Java集合框架(下)
    浅入深出之Java集合框架(中)
    浅入深出之Java集合框架(上)
    全面解释java中StringBuilder、StringBuffer、String类之间的关系
  • 原文地址:https://www.cnblogs.com/changzhendong/p/11151852.html
Copyright © 2011-2022 走看看