詳解python數(shù)據(jù)結(jié)構(gòu)和算法
1.刪除序列相同元素并保持順序
如果僅僅就是想消除重復(fù)元素,通常可以簡單的構(gòu)造一個集合,利用集合之間元素互不相同的特性就可以消除重復(fù),但是這種方法生成的結(jié)果中元素的位置會被打亂。下面是我們的解決方案:
主要思想就是構(gòu)造一個集合,然后遍歷該列表,如果當(dāng)前元素不存在集合中就將該元素返回。
yiled時python中構(gòu)造生成器的關(guān)鍵字。碰到y(tǒng)iled就返回該變量,下一次則從yiled之后的語句開始執(zhí)行。
使用示例:
注:我們構(gòu)造的dedupe函數(shù)返回的是生成器對象,需要用list轉(zhuǎn)化成可直接輸出的列表。
該函數(shù)也可以用來文件去除重復(fù)行:
2.過濾元素序列
問題--------你有一個數(shù)據(jù)序列,想利用一些規(guī)則從中提取出需要的值或者是縮短序列
方法一:最簡單的過濾序列元素的方法就是使用列表推導(dǎo)。比如我們想從下列列表中提取正數(shù):
方法二:生成器迭代
使用列表推導(dǎo)的一個潛在缺陷就是如果輸入非常大的時候會產(chǎn)生一個非常大的結(jié)果集,占用大量內(nèi)存。 如果你對內(nèi)存比較敏感,那么你可以使用生成器表達(dá)式迭代產(chǎn)生過濾的元素。
運(yùn)行結(jié)果:
方法三:過濾規(guī)則比較復(fù)雜,不能簡單的在列表推導(dǎo)或者生成器表達(dá)式中表達(dá)出來時需要考慮使用內(nèi)建的filter函數(shù)。這時候你可以將過濾代碼放到一個函數(shù)中, 然后使用內(nèi)建的 filter() 函數(shù)。示例如下:
以上所述是小編給大家介紹的python數(shù)據(jù)結(jié)構(gòu)和算法詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對好吧啦網(wǎng)網(wǎng)的支持!
相關(guān)文章:
1. jsp網(wǎng)頁實現(xiàn)貪吃蛇小游戲2. SpringMVC+Jquery實現(xiàn)Ajax功能3. HTML5 Canvas繪制圖形從入門到精通4. JavaScript實現(xiàn)組件化和模塊化方法詳解5. .Net Core和RabbitMQ限制循環(huán)消費(fèi)的方法6. 淺談SpringMVC jsp前臺獲取參數(shù)的方式 EL表達(dá)式7. ASP.NET MVC遍歷驗證ModelState的錯誤信息8. jsp+servlet簡單實現(xiàn)上傳文件功能(保存目錄改進(jìn))9. ASP中if語句、select 、while循環(huán)的使用方法10. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明
