python set集合的基本运算

冻结的集合

一般的集合set都是可原处修改的集合。还有一种集合,不能在原处修改。
这种集合的创建方法是: frozenset("hiekay")

>>> f_set = frozenset("hiekay")     #看这个名字就知道了frozen,冻结的set
>>> f_set
frozenset(['h', 'i', 'e', 'k', 'a','y'])
>>> f_set.add("python")             #报错
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'frozenset' object has no attribute 'add'

>>> a_set = set("github")           #对比看一看,这是一个可以原处修改的set
>>> a_set
set(['b', 'g', 'i', 'h', 'u', 't'])
>>> a_set.add("python")
>>> a_set
set(['b', 'g', 'i', 'h', 'python', 'u', 't'])

集合运算

元素与集合的关系

元素是否属于某个集合。

>>> aset
set(['h', 'o', 'n', 'p', 't', 'y'])
>>> "a" in aset
False
>>> "h" in aset
True

集合与集合的关系

假设两个集合A、B

  • A是否等于B,即两个集合的元素完全一样

在交互模式下实验

>>> a = set("abcde")
>>> b = set("abfgh")
>>> a
set(['a', 'b', 'c', 'd', 'e'])
>>> b
set(['a', 'b', 'f', 'g', 'h'])
>>> a == b
False
>>> a != b
True

  • A是否是B的子集,或者反过来,B是否是A的超集。即A的元素也都是B的元素,但是B的元素比A的元素数量多。

实验:

>>> c = set("ab")
>>> a
set(['a', 'c', 'b', 'e', 'd'])
>>> c
set(['a', 'b'])
>>> c<a     #c是a的子集
True
>>> c.issubset(a)   #或者用这种方法,判断c是否是a的子集
True
>>> a.issuperset(c) #判断a是否是c的超集
True

>>> b
set(['a', 'h', 'b', 'g', 'f'])
>>> a<b     #a不是b的子集
False
>>> a.issubset(b)   #或者这样做
False

  • A、B的并集,即A、B所有元素,如下图所示
image
>>> a
set(['a', 'c', 'b', 'e', 'd'])
>>> b
set(['a', 'h', 'b', 'g', 'f'])
>>> a | b                       #可以有两种方式,结果一样
set(['a', 'c', 'b', 'e', 'd', 'g', 'f', 'h'])
>>> a.union(b)
set(['a', 'c', 'b', 'e', 'd', 'g', 'f', 'h'])
  • A、B的交集,即A、B所公有的元素,如下图所示
image
>>> a
set(['a', 'c', 'b', 'e', 'd'])
>>> b
set(['a', 'h', 'b', 'g', 'f'])
>>> a & b       #两种方式,等价
set(['a', 'b'])
>>> a.intersection(b)
set(['a', 'b'])

实验:

>>> a and b
set(['a', 'h', 'b', 'g', 'f'])
  • A相对B的差(补),即A相对B不同的部分元素,如下图所示
image
>>> a
set(['a', 'c', 'b', 'e', 'd'])
>>> b
set(['a', 'h', 'b', 'g', 'f'])
>>> a - b
set(['c', 'e', 'd'])
>>> a.difference(b)
set(['c', 'e', 'd'])

-A、B的对称差集,如下图所示

image
>>> a
set(['a', 'c', 'b', 'e', 'd'])
>>> b
set(['a', 'h', 'b', 'g', 'f'])
>>> a.symmetric_difference(b)
set(['c', 'e', 'd', 'g', 'f', 'h'])

以上是集合的基本运算。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 9,076评论 0 13
  • 一、Python简介和环境搭建以及pip的安装 4课时实验课主要内容 【Python简介】: Python 是一个...
    _小老虎_阅读 5,883评论 0 10
  • 你不是天才,但绝对不会碌碌无为。 因为我相信你,和成功近在咫尺。你也有无数的创意,你也有大胆的想法,对你而言,最难...
    脑洞少年阅读 245评论 0 0
  • 七月份的大连比想象中的闷热潮湿,有时会让人闷得透不过气来。今起的尚早,无心做事翻来朋友圈,偶然看见了金驰已经入围...
    季马阅读 181评论 0 0
  • 如是我闻: 不识万显即游戏,疑法之人骄慢大,菩提悲心未生者,净垢之心分别重,心若不常念成佛,虽名学佛不真实,终为世...
    睡一夜就馊星人阅读 159评论 0 2