>>f_set=frozenset("qiwsir")#看這個(gè)名字就知道了frozen,凍結(jié)的set>>>f_setfrozenset(['q','i','s','r','w'])>>>f_set.add("python")#報(bào)錯(cuò)Traceback(mostrecentcalllast):File"",line1,in" />

黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

跟老齊學(xué)Python之集合的關(guān)系

系統(tǒng) 1981 0

凍結(jié)的集合

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

            
>>> f_set = frozenset("qiwsir")   #看這個(gè)名字就知道了frozen,凍結(jié)的set
>>> f_set
frozenset(['q', 'i', 's', 'r', 'w'])
>>> f_set.add("python")       #報(bào)錯(cuò)
Traceback (most recent call last):
 File "
            
              ", line 1, in 
              
                
AttributeError: 'frozenset' object has no attribute 'add'

>>> a_set = set("github")      #對(duì)比看一看,這是一個(gè)可以原處修改的set
>>> a_set
set(['b', 'g', 'i', 'h', 'u', 't'])
>>> a_set.add("python")
>>> a_set
set(['b', 'g', 'i', 'h', 'python', 'u', 't'])


              
            
          

集合運(yùn)算

先復(fù)習(xí)一下中學(xué)數(shù)學(xué)(準(zhǔn)確說(shuō)是高中數(shù)學(xué)中的一點(diǎn)知識(shí))中關(guān)于集合的一點(diǎn)知識(shí),主要是喚起那痛苦而青澀美麗的回憶吧,至少對(duì)我是。

元素與集合的關(guān)系

元素是否屬于某個(gè)集合。

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

          

集合與集合的糾結(jié)

假設(shè)兩個(gè)集合A、B

A是否等于B,即兩個(gè)集合的元素完全一樣
在交互模式下實(shí)驗(yàn)

            
>>> a      
set(['q', 'i', 's', 'r', 'w'])
>>> b
set(['a', 'q', 'i', 'l', 'o'])
>>> a == b
False
>>> a != b
True

          

A是否是B的子集,或者反過(guò)來(lái),B是否是A的超集。即A的元素也都是B的元素,但是B的元素比A的元素?cái)?shù)量多。
實(shí)驗(yàn)一下

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


            
>>> a
set(['q', 'i', 's', 'r', 'w'])
>>> b
set(['a', 'q', 'i', 'l', 'o'])
>>> a | b            #可以有兩種方式,結(jié)果一樣
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所公有的元素,如下圖所示


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

          

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

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

          

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


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

          

-A、B的對(duì)稱差集,如下圖所示

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

          

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


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦?。?!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論