久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

瀏覽:7日期:2022-08-07 18:37:42

1.刪除序列相同元素并保持順序

如果僅僅就是想消除重復(fù)元素,通常可以簡(jiǎn)單的構(gòu)造一個(gè)集合,利用集合之間元素互不相同的特性就可以消除重復(fù),但是這種方法生成的結(jié)果中元素的位置會(huì)被打亂。下面是我們的解決方案:

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

主要思想就是構(gòu)造一個(gè)集合,然后遍歷該列表,如果當(dāng)前元素不存在集合中就將該元素返回。

yiled時(shí)python中構(gòu)造生成器的關(guān)鍵字。碰到y(tǒng)iled就返回該變量,下一次則從yiled之后的語(yǔ)句開(kāi)始執(zhí)行。

使用示例:

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

注:我們構(gòu)造的dedupe函數(shù)返回的是生成器對(duì)象,需要用list轉(zhuǎn)化成可直接輸出的列表。

該函數(shù)也可以用來(lái)文件去除重復(fù)行:

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

2.過(guò)濾元素序列

問(wèn)題--------你有一個(gè)數(shù)據(jù)序列,想利用一些規(guī)則從中提取出需要的值或者是縮短序列

方法一:最簡(jiǎn)單的過(guò)濾序列元素的方法就是使用列表推導(dǎo)。比如我們想從下列列表中提取正數(shù):

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

方法二:生成器迭代

使用列表推導(dǎo)的一個(gè)潛在缺陷就是如果輸入非常大的時(shí)候會(huì)產(chǎn)生一個(gè)非常大的結(jié)果集,占用大量?jī)?nèi)存。 如果你對(duì)內(nèi)存比較敏感,那么你可以使用生成器表達(dá)式迭代產(chǎn)生過(guò)濾的元素。

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

運(yùn)行結(jié)果:

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

方法三:過(guò)濾規(guī)則比較復(fù)雜,不能簡(jiǎn)單的在列表推導(dǎo)或者生成器表達(dá)式中表達(dá)出來(lái)時(shí)需要考慮使用內(nèi)建的filter函數(shù)。這時(shí)候你可以將過(guò)濾代碼放到一個(gè)函數(shù)中, 然后使用內(nèi)建的 filter() 函數(shù)。示例如下:

詳解python數(shù)據(jù)結(jié)構(gòu)和算法

以上所述是小編給大家介紹的python數(shù)據(jù)結(jié)構(gòu)和算法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)好吧啦網(wǎng)網(wǎng)的支持!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 肇东市| 土默特右旗| 松原市| 都昌县| 冀州市| 突泉县| 中牟县| 三穗县| 清水县| 双辽市| 措勤县| 都江堰市| 平南县| 兰西县| 保山市| 太仓市| 张家口市| 平顶山市| 临夏市| 浑源县| 奉节县| 台东县| 安溪县| 许昌县| 犍为县| 巴林右旗| 灌南县| 朔州市| 辽阳县| 赣州市| 正蓝旗| 伊宁县| 太保市| 老河口市| 化州市| 彭泽县| 雷波县| 黔江区| 建昌县| 巴中市| 绥化市|