zoukankan      html  css  js  c++  java
  • 集合

    1.定义集合

      定义:不同的元素组成,无序排列的可hash的值,可以理解为k值

        特性:不同的元素存放到一起集合间进行关系运算,不用考虑如何把元素取出来。

    2.集合创建

     可变集合:
    >>> set_test=set('hello')
    >>> set_test
     改为不可变集合:
    forset = frozenset(set_test)

    3.集合关系运算

        in
    not in
    ==
    !=
    <,<=
    >,>=
    |,|=:合集
    &.&=:交集
    -,-=:差集
    ^,^=:对称差分

    4.集合常用函数

      linuxs={'wupeiqi','oldboy','tiedan'}

      linuxs.add() 

    1 linuxs.add('laowang')
    2 print(linuxs)
    3 #{'wupeiqi', 'laowang', 'tiedan', 'oldboy'}

      linuxs.pop()

    1 linuxs.pop() 
    2 print(linuxs) 
    3 #{'oldboy', 'wupeiqi'}(随机取)有返回值 

      linuxs.remove()

    1 linuxs.remove('oldboy')
    2 print(linuxs)
    3 #{'tiedan', 'wupeiqi'} 没有返回值,没有的值会报错

      linuxs.discard()

    1 linuxs.discard('oldboyklkl')
    2 print(linuxs)
    3 #{'wupeiqi', 'tiedan', 'oldboy'} 没有的值不会报错,没有返回值

      linuxs.update()

    1 linuxs.update('oldboyklkl')
    2 print(linuxs)
    3 #更新到原先集合中

      linuxs.clear()

    1 linuxs.clear()
    2 print(linuxs)
    3 #set()  空集合

      linuxs.copy()

    1 a = linuxs.copy()
    2 linuxs.clear()#删除以后,集合a仍然可以打印出来
    3 print(a)
    4 #{'tiedan', 'oldboy', 'wupeiqi'}

      linuxs.diference_update()

    1 linuxs.difference_update({'okay','tiedan'})
    2 print(linuxs)
    3 #去掉原先集合中与第二个集合元素的交集,更新到原先集合中,对第二个集合没有影响,{'oldboy', 'wupeiqi'}

        linuxs.discard()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy'}
    2 linuxs.discard('oldboylll')
    3 print(linuxs) #{'oldboy', 'yy', 'wupeiqi', 'niucha', 'tiedan'}
    4 #去掉第一个集合与第二个集合的交集,没有返回值

         linuxs.intersection()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 liu = linuxs.intersection({'niucha','oldboy','xx'})
    3 print(liu) 
    4 #{'niucha', 'xx', 'oldboy'} 
    5 #取两个集合的交集,并返回一个新的集合

        linuxs.intersection_update()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 linuxs.intersection_update({'niucha','oldboy','xx'})
    3 print(linuxs)
    4 #{'oldboy', 'xx', 'niucha'}
    5 #两个集合的交集组成一个新的集合,并更新到第一个集合中,没有返回值

        linuxs.isdisjoint()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 liu = linuxs.isdisjoint({'niucha','oldboy','xx'})
    3 #False
    4 #判断两个集合的交集是否为空,如果不为空,返回False

         linuxs.issubset()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 b = linuxs.issubset({'wupeiqi','oldboy','tiedan','niucha','yy','xx','aaa'})
    3 print(b)#True
    4 #判断第一个集合是否含于第二个集合,即s1 <= s2

        linuxs.issuperset()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 liu = linuxs.issuperset({'niucha','oldboy','xx'})
    3 print(liu) #True 
    4 #判断第一个集合是否完全包含第二个集合,如果完全包含返回Ture,否则返回False

          linuxs.symmetric_difference()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 liu = linuxs.symmetric_difference({'niucha','oldboy','ccc'})
    3 print(liu) #{'tiedan', 'wupeiqi', 'xx', 'ccc', 'yy'}
    4 #去掉两个集合的差值,将两个集合的非交集组成一个新的集合并返回

       linuxs.symmetric_difference_update()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 linuxs.symmetric_difference_update({'niucha','oldboy','ccc'})
    3 print(linuxs)#{'wupeiqi', 'xx', 'yy', 'ccc', 'tiedan'}
    4 #去掉两个集合的交集,并把第二个集合中的元素更新到第一个集合中,组成一个新的集合

       linuxs.union()

    1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
    2 liu = linuxs.union({'niucha','oldboy','ccc'})
    3 print(liu) #{'wupeiqi', 'tiedan', 'xx', 'oldboy', 'niucha', 'yy', 'ccc'}
    4 # 将两个集合的元素组成一个新的集合
  • 相关阅读:
    域hash值破解的总结经验
    centos下安装ngnix+php+mysql服务
    方程式EQGRP_Lost_in_Translation工具之fb.py
    Bypass AV meterpreter免杀技巧
    跟我一起创建栈
    vue-cli3使用yarn run build打包找不到路径
    使用vue-cli3快速适配H5项目
    关于判断是安卓还是ios环境跳转下载页
    跟我一起学习webpack输出动态HTML(三)
    跟我一起学习webpack使用配置文件(二)
  • 原文地址:https://www.cnblogs.com/sxh-myblogs/p/7217881.html
Copyright © 2011-2022 走看看