Python数据结构:集合

发布时间:2019-03-02 10:49:08编辑:auto阅读(2292)

    • 集合的定义

     使用大括号,并且里面必须有初始值,否则是dict字典类型

    • 集合的特征

    集合内部的元素无序,所以不能使用索引、切片等操作

    集合内部的元素具有唯一性,不允许元素重复出现

    集合内部的元素,只能存放int, float, str, tuple等必须是可哈希的数据,set类型本身不可哈希

    s1 = {1,2,3,'a','b','c',7,8,9}
    s2 = {}
    
    print(type(s1)) #输出<class 'set'>
    print(type(s2)) #输出<class 'dict'>
    
    for i in s1:
        print(i,end=' ') #输出1 2 3 b 7 8 9 a c,可见set是无序的
    •  多循环的集合内涵
    s1 = {1,2,3}
    s2 = {'i', 'love', 'you'}
    
    s3 = {m * n for m in s2 for n in s1} #相当于把s2中的每个元素乘以1/2/3
    print(s3) #输出{'iii', 'lovelove', 'you', 'youyou', 'i', 'youyouyou', 'ii', 'love', 'lovelovelove'}
    •  删除元素
    s = {'a','b','c','d','e','f'}
    # s.remove('k') #remove删除不存在的元素报错keyerror
    s.discard('k') #discard删除不存在的元素不报错,只是删除失败而已
    • 交叉并补

    交集intersection

    差集difference

    并集union

    子集issubset:检查一个集合是否为另一个集合的子集

    超集issuperset:检查一个集合是否为另一个集合的超集(如果一个集合S2中的每一个元素都在集合S1中,且集合S1中可能包含S2中没有的元素,则集合S1就是S2的一个超集,反过来,S2是S1的子集)

    s1 = {1,2,3,4,5,6}
    s2 = {5,6,7,8,9,0}
    
    s3 = s1.intersection(s2) #s1与s2的交集
    print(s3) #输出{5, 6}
    
    s4 = s1.difference(s2) #s1与s2的差集,相当于s1-s2
    print(s4) #输出{1, 2, 3, 4}
    
    s5 = s1.union(s2) #s1与s2的并集
    print(s5) #输出{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
    
    i1 = s1.issubset(s2) #判断s2是否为s1的子集,i1为False
    i2 = s1.issuperset(s2) #判断s2是否为s1的超集,i2为False
    •  冰冻集合

    不可以进行任何修改操作的集合,其他属性与集合完全一致。

    s = {1,2,3}
    s = frozenset(s)
    print(s) #输出frozenset({1, 2, 3})

     

关键字