• 集合的相关内容


    set集合
    set集合是python的一个基本数据类型. 一般不是很常用. set中的元素是不重复的.无序的.一般可以通过set() 对列表等进行去重,里面的元素必须是可hash的(int, str, tuple,bool), 我们可以这样来记. set就是dict类型的数据但是不保存value, 只保存key. set也用{}表示

    空集合的创建 gg = set()

    注意: set集合中的元素必须是可hash的, 但是set本身是不可hash得. set是可变的. 

    set集合增删改查
    1. 增加
    s = {"刘嘉玲", '关之琳', "王祖贤"}
    s.add("郑裕玲")
    print(s)
    s.add("郑裕玲") # 重复的内容不不会被添加到set集合中
    print(s)
    s = {"刘嘉玲", '关之琳', "王祖贤"}
    s.update("麻花藤") # 迭代更更新
    print(s)
    s.update(["张曼玉", "李若彤","李若彤"])
    print(s)

    2. 删除
    s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}
    item = s.pop() # 随机弹出一个.
    print(s)
    print(item)
    s.remove("关之琳") # 直接删除元素
    # s.remove("马虎疼") # 不存在这个元素. 删除会报错
    print(s)
    s.clear() # 清空set集合.需要注意的是set集合如果是空的. 打印出来是set() 因为要和
    dict区分的.
    print(s) # set()

    3. 修改
    # set集合中的数据没有索引. 也没有办法去定位一个元素. 所以没有办法进行行直接修改.
    # 我们可以采用先删除后添加的方式来完成修改操作
    s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}
    # 把刘嘉玲改成赵本山
    s.remove("刘嘉玲")
    s.add("赵本山")
    print(s)

    查询
    # set是一个可迭代对象. 所以可以进行for循环
    for el in s:
      print(el)

    5. 常用操作
    s1 = {"刘能", "赵四", "皮长山"}
    s2 = {"刘科长", "冯乡长", "皮长山"}
    # 交集
    # 两个集合中的共有元素
    print(s1 & s2)    # {'皮长山'}
    print(s1.intersection(s2))   # {'皮长山'}

    # 并集

    print(s1 | s2) # {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}
    print(s1.union(s2)) # {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}

    # 差集
    print(s1 - s2) # {'赵四', '刘能'} 得到第一个中单独存在的
    print(s1.difference(s2)) # {'赵四', '刘能'}

    # 反交集
    print(s1 ^ s2) # 两个集合中单独存在的数据 {'冯乡长', '刘能', '刘科长', '赵四'}
    print(s1.symmetric_difference(s2)) # {'冯乡长', '刘能', '刘科长', '赵四'}

    s1 = {"刘能", "赵四"}
    s2 = {"刘能", "赵四", "⽪皮⻓长⼭山"}

    # 子集
    print(s1 < s2) # set1是set2的子集吗? True
    print(s1.issubset(s2))

    # 超集
    print(s1 > s2) # set1是set2的超集吗? False
    print(s1.issuperset(s2))

    set集合本身是可以发生改变的. 是不可hash的. 我们可以使用frozenset来保存数据.
    frozenset是不可变的. 也就是一个可哈希的数据类型

    s = frozenset(["赵本山", "刘能", "皮长山", "长跪"])
    dic = {s:'123'} # 可以正常使用了了
    print(dic)

  • 相关阅读:
    每日一题力扣222 完全二叉树节点的个数
    236 二叉树的最近公共祖先
    每日一题力扣122
    每日一题力扣 100 相同的树
    每日一题力扣617 合并二叉树
    每日一题力扣226
    每日一题力扣101 对称子树
    腾讯 qq 与 360 打架, 腾讯qq 无理
    决定把 blog 从 csdn.net 迁移到 cnblogs.com
    发现 google 网站管理员工具中给出的 javascript 代码是错误的
  • 原文地址:https://www.cnblogs.com/vivi0403/p/9850294.html
Copyright © 2020-2023  润新知