国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

跟老齊學Python之集合的關系

2019-11-25 18:12:22
字體:
來源:轉載
供稿:網友

凍結的集合

前面一節講述了集合的基本概念,注意,那里所涉及到的集合都是可原處修改的集合。還有一種集合,不能在原處修改。這種集合的創建方法是:

>>> f_set = frozenset("qiwsir")   #看這個名字就知道了frozen,凍結的set>>> f_setfrozenset(['q', 'i', 's', 'r', 'w'])>>> 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_setset(['b', 'g', 'i', 'h', 'u', 't'])>>> a_set.add("python")>>> a_setset(['b', 'g', 'i', 'h', 'python', 'u', 't'])

集合運算

先復習一下中學數學(準確說是高中數學中的一點知識)中關于集合的一點知識,主要是喚起那痛苦而青澀美麗的回憶吧,至少對我是。

元素與集合的關系

元素是否屬于某個集合。

>>> asetset(['h', 'o', 'n', 'p', 't', 'y'])>>> "a" in asetFalse>>> "h" in asetTrue

集合與集合的糾結

假設兩個集合A、B

A是否等于B,即兩個集合的元素完全一樣
在交互模式下實驗

>>> a      set(['q', 'i', 's', 'r', 'w'])>>> bset(['a', 'q', 'i', 'l', 'o'])>>> a == bFalse>>> a != bTrue

A是否是B的子集,或者反過來,B是否是A的超集。即A的元素也都是B的元素,但是B的元素比A的元素數量多。
實驗一下

>>> aset(['q', 'i', 's', 'r', 'w'])>>> cset(['q', 'i'])>>> c<a   #c是a的子集True>>> c.issubset(a)  #或者用這種方法,判斷c是否是a的子集True>>> a.issuperset(c) #判斷a是否是c的超集True>>> bset(['a', 'q', 'i', 'l', 'o'])>>> a<b   #a不是b的子集False>>> a.issubset(b)  #或者這樣做False

A、B的并集,即A、B所有元素,如下圖所示


>>> aset(['q', 'i', 's', 'r', 'w'])>>> bset(['a', 'q', 'i', 'l', 'o'])>>> a | b            #可以有兩種方式,結果一樣set(['a', 'i', 'l', 'o', 'q', 's', 'r', 'w'])>>> a.union(b)set(['a', 'i', 'l', 'o', 'q', 's', 'r', 'w'])

A、B的交集,即A、B所公有的元素,如下圖所示


>>> aset(['q', 'i', 's', 'r', 'w'])>>> bset(['a', 'q', 'i', 'l', 'o'])>>> a & b    #兩種方式,等價set(['q', 'i'])>>> a.intersection(b)set(['q', 'i'])

我在實驗的時候,順手敲了下面的代碼,出現的結果如下,看官能解釋一下嗎?(思考題)

>>> a and bset(['a', 'q', 'i', 'l', 'o'])

A相對B的差(補),即A相對B不同的部分元素,如下圖所示


>>> aset(['q', 'i', 's', 'r', 'w'])>>> bset(['a', 'q', 'i', 'l', 'o'])>>> a - bset(['s', 'r', 'w'])>>> a.difference(b)set(['s', 'r', 'w'])

-A、B的對稱差集,如下圖所示

>>> aset(['q', 'i', 's', 'r', 'w'])>>> bset(['a', 'q', 'i', 'l', 'o'])>>> a.symmetric_difference(b)set(['a', 'l', 'o', 's', 'r', 'w'])

以上是集合的基本運算。在編程中,如果用到,可以用前面說的方法查找。不用死記硬背。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 普兰店市| 游戏| 沁源县| 万源市| 孙吴县| 天全县| 苏尼特左旗| 二手房| 休宁县| 萝北县| 昌宁县| 永川市| 清苑县| 涿鹿县| 阆中市| 建湖县| 彭州市| 聂拉木县| 镇康县| 玛沁县| 左云县| 库伦旗| 宁安市| 鹤壁市| 冕宁县| 镇远县| 洪雅县| 鄢陵县| 鸡西市| 化隆| 澄江县| 电白县| 凌海市| 吉木萨尔县| 渭源县| 沈阳市| 青冈县| 普陀区| 桃园县| 香格里拉县| 乐亭县|