黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Python編程中3個常用的數據結構和算法

Python編程中3個常用的數據結構和算法

來源:千鋒教育
發布人:xqq
時間: 2023-11-07 07:15:56 1699312556

python內置了許多非常有用的數據結構,比如列表(list)、集合(set)以及字典(dictionary)。就絕大部分情況而言,我們可以直接使用這些數據結構。但是,通常我們還需要考慮比如搜索、排序、排列以及篩選等這一類常見的問題。

本篇文章將介紹3種常見的數據結構和同數據有關的算法。此外,在collections模塊中也包含了針對各種數據結構的解決方案。

1.將序列分解為單獨的變量

(1)問題

我們有一個包含N個元素的元組或序列,現在想將它分解為N個單獨的變量。

(2)解決方案

任何序列(或可迭代的對象)都可以通過一個簡單的賦值操作來分解為單獨的變量。唯一的要求是變量的總數和結構要與序列相吻合。例如:

>>>p=(4,5)

>>>x,y=p

>>>x

4

>>>y

5

>>>

>>>data=['ACME',50,91.1,(2012,12,21)]

>>>name,shares,price,date=data

>>>name

'ACME'

>>>date

(2012,12,21)

>>>name,shares,price,(year,mon,day)=data

>>>name

'ACME'

>>>year

2012

>>>mon

12

>>>day

21

>>>

如果元素的數量不匹配,將得到一個錯誤提示。例如:

>>>p=(4,5)

>>>x,y,z=p

Traceback(mostrecentcalllast):

File"",line1,in

ValueError:needmorethan2valuestounpack

>>>

(3)討論

實際上不僅僅只是元組或列表,只要對象恰好是可迭代的,那么就可以執行分解操作。這包括字符串、文件、迭代器以及生成器。比如:

>>>s='Hello'

>>>a,b,c,d,e=s

>>>a

'H'

>>>b

'e'

>>>e

'o'

>>>

當做分解操作時,有時候可能想丟棄某些特定的值。Python并沒有提供特殊的語法來實現這一點,但是通常可以選一個用不到的變量名,以此來作為要丟棄的值的名稱。例如:

>>>data=['ACME',50,91.1,(2012,12,21)]

>>>_,shares,price,_=data

>>>shares

50

>>>price

91.1

>>>

但是請確保選擇的變量名沒有在其他地方用到過。

2.從任意長度的可迭代對象中分解元素

(1)問題

需要從某個可迭代對象中分解出N個元素,但是這個可迭代對象的長度可能超過N,這會導致出現“分解的值過多(toomanyvaluestounpack)”的異常。

(2)解決方案

Python的“*表達式”可以用來解決這個問題。例如,假設開設了一門課程,并決定在期末的作業成績中去掉第一個和最后一個,只對中間剩下的成績做平均分統計。如果只有4個成績,也許可以簡單地將4個都分解出來,但是如果有24個呢?*表達式使這一切都變得簡單:

defdrop_first_last(grades):

first,*middle,last=grades

returnavg(middle)

另一個用例是假設有一些用戶記錄,記錄由姓名和電子郵件地址組成,后面跟著任意數量的電話號碼。則可以像這樣分解記錄:

>>>record=('Dave','dave@example.com','773-555-1212','847-555-1212')

>>>name,email,*phone_numbers=user_record

>>>name

'Dave'

>>>email

'dave@example.com'

>>>phone_numbers

['773-555-1212','847-555-1212']

>>>

不管需要分解出多少個電話號碼(甚至沒有電話號碼),變量phone_numbers都一直是列表,而這是毫無意義的。如此一來,對于任何用到了變量phone_numbers的代碼都不必對它可能不是一個列表的情況負責,或者額外做任何形式的類型檢查。

由*修飾的變量也可以位于列表的第一個位置。例如,比方說用一系列的值來代表公司過去8個季度的銷售額。如果想對最近一個季度的銷售額同前7個季度的平均值做比較,可以這么做:

*trailing_qtrs,current_qtr=sales_record

trailing_avg=sum(trailing_qtrs)/len(trailing_qtrs)

returnavg_comparison(trailing_avg,current_qtr)

從Python解釋器的角度來看,這個操作是這樣的:

>>>*trailing,current=[10,8,7,1,9,5,10,3]

>>>trailing

[10,8,7,1,9,5,10]

>>>current

3

(3)討論

對于分解未知或任意長度的可迭代對象,這種擴展的分解操作可謂是量身定做的工具。通常,這類可迭代對象中會有一些已知的組件或模式(例如,元素1之后的所有內容都是電話號碼),利用*表達式分解可迭代對象使得開發者能夠輕松利用這些模式,而不必在可迭代對象中做復雜花哨的操作才能得到相關的元素。

*式的語法在迭代一個變長的元組序列時尤其有用。例如,假設有一個帶標記的元組序列:

records=[

('foo',1,2),

('bar','hello'),

('foo',3,4),

]

defdo_foo(x,y):

print('foo',x,y)

defdo_bar(s):

print('bar',s)

fortag,*argsinrecords:

iftag=='foo':

do_foo(*args)

eliftag=='bar':

do_bar(*args)

當和某些特定的字符串處理操作相結合,比如做拆分(splitting)操作時,這種*式的語法所支持的分解操作也非常有用。例如:

>>>line='nobody:*:-2:-2:UnprivilegedUser:/var/empty:/usr/bin/false'

>>>uname,*fields,homedir,sh=line.split(':')

>>>uname

'nobody'

>>>homedir

'/var/empty'

>>>sh

'/usr/bin/false'

>>>

有時候可能想分解出某些值然后丟棄它們。在分解的時候,不能只是指定一個單獨的*,但是可以使用幾個常用來表示待丟棄值的變量名,比如_或者ign(ignored)。例如:

>>>record=('ACME',50,123.45,(12,18,2012))

>>>name,*_,(*_,year)=record

>>>name

'ACME'

>>>year

2012

>>>

*分解操作和各種函數式語言中的列表處理功能有著一定的相似性。例如,如果有一個列表,可以像下面這樣輕松將其分解為頭部和尾部:

>>>items=[1,10,7,4,5,9]

>>>head,*tail=items

>>>head

1

>>>tail

[10,7,4,5,9]

>>>

在編寫執行這類拆分功能的函數時,人們可以假設這是為了實現某種精巧的遞歸算法。例如:

>>>defsum(items):

...head,*tail=items

...returnhead+sum(tail)iftailelsehead

...

>>>sum(items)

36

>>>

但是請注意,遞歸真的不算是Python的強項,這是因為其內在的遞歸限制所致。因此,最后一個例子在實踐中沒太大的意義,只不過是一點學術上的好奇罷了。

3.保存最后N個元素

(1)問題

我們希望在迭代或是其他形式的處理過程中對最后幾項記錄做一個有限的歷史記錄統計。

(2)解決方案

保存有限的歷史記錄可算是collections.deque的完美應用場景了。例如,下面的代碼對一系列文本行做簡單的文本匹配操作,當發現有匹配時就輸出當前的匹配行以及最后檢查過的N行文本。

fromcollectionsimportdeque

defsearch(lines,pattern,history=5):

previous_lines=deque(maxlen=history)

forlineinlines:

ifpatterninline:

yieldline,previous_lines

previous_lines.append(line)

#Exampleuseonafile

if__name__=='__main__':

withopen('somefile.txt')asf:

forline,prevlinesinsearch(f,'python',5):

forplineinprevlines:

print(pline,end='')

print(line,end='')

print('-'*20)

(3)討論

如同上面的代碼片段中所做的一樣,當編寫搜索某項記錄的代碼時,通常會用到含有yield關鍵字的生成器函數。這將處理搜索過程的代碼和使用搜索結果的代碼成功解耦開來。如果對生成器還不熟悉,請參見4.3節。

deque(maxlen=N)創建了一個固定長度的隊列。當有新記錄加入而隊列已滿時會自動移除最老的那條記錄。例如:

>>>q=deque(maxlen=3)

>>>q.append(1)

>>>q.append(2)

>>>q.append(3)

>>>q

deque([1,2,3],maxlen=3)

>>>q.append(4)

>>>q

deque([2,3,4],maxlen=3)

>>>q.append(5)

>>>q

deque([3,4,5],maxlen=3)

盡管可以在列表上手動完成這樣的操作(append、del),但隊列這種解決方案要優雅得多,運行速度也快得多。

更普遍的是,當需要一個簡單的隊列結構時,deque可祝你一臂之力。如果不指定隊列的大小,也就得到了一個無界限的隊列,可以在兩端執行添加和彈出操作,例如:

>>>q=deque()

>>>q.append(1)

>>>q.append(2)

>>>q.append(3)

>>>q

deque([1,2,3])

>>>q.appendleft(4)

>>>q

deque([4,1,2,3])

>>>q.pop()

3

>>>q

deque([4,1,2])

>>>q.popleft()

4

從隊列兩端添加或彈出元素的復雜度都是O(1)。這和列表不同,當從列表的頭部插入或移除元素時,列表的復雜度為O(N)。

以上內容為大家介紹了Python編程中3個常用的數據結構和算法,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。http://www.e7g2kmi.cn/

tags: python培訓
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
国产高清视频免费| 欧美日本韩国| 国产成人精品综合久久久| 国产不卡在线播放| 一级女性全黄生活片免费| 国产美女在线观看| 久久成人亚洲| 九九久久国产精品| 九九久久国产精品大片| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产一区免费在线观看| 亚洲第一色在线| 免费一级片在线观看| 欧美另类videosbestsex高清| 免费毛片播放| 亚洲 国产精品 日韩| 日韩在线观看视频黄| 四虎论坛| 国产网站在线| 99久久精品费精品国产一区二区| 欧美日本二区| 成人影视在线观看| 久久国产影院| 91麻豆国产级在线| 青青青草影院 | 美女免费毛片| 国产a视频| 欧美激情一区二区三区在线 | 成人高清护士在线播放| 国产欧美精品午夜在线播放| 99久久精品费精品国产一区二区| 你懂的日韩| 亚洲 国产精品 日韩| 91麻豆高清国产在线播放| 精品国产三级a∨在线观看| 国产高清视频免费| 毛片电影网| 日韩中文字幕在线观看视频| 久久国产精品自线拍免费| 黄色福利| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品视频在线观看视频免费视频| 精品国产一区二区三区久| 黄色免费三级| 国产不卡在线观看视频| 国产网站麻豆精品视频| 欧美一级视频高清片| 九九免费精品视频| 超级乱淫伦动漫| 日本在线不卡免费视频一区| 一级女性全黄生活片免费| 国产精品1024永久免费视频| 成人在免费观看视频国产| 青青青草影院| 91麻豆精品国产自产在线| 深夜做爰性大片中文| 国产成人精品综合在线| 91麻豆精品国产片在线观看| 超级乱淫黄漫画免费| 精品视频免费在线| 国产不卡福利| 欧美爱色| 久草免费在线观看| 久久99中文字幕| a级黄色毛片免费播放视频| 九九免费高清在线观看视频| 韩国三级视频在线观看| 欧美国产日韩一区二区三区| 久久久成人影院| 日韩专区在线播放| 一本伊大人香蕉高清在线观看| 国产91精品一区二区| 99久久视频| 午夜在线亚洲| 欧美激情一区二区三区在线 | 深夜做爰性大片中文| 国产视频一区二区在线播放| 欧美大片一区| 999精品视频在线| 一级女性全黄久久生活片| 999久久66久6只有精品| 黄色免费三级| 高清一级片| 国产不卡在线播放| 日韩专区亚洲综合久久| 99久久网站| 欧美大片aaaa一级毛片| 国产激情一区二区三区| 国产国语对白一级毛片| 韩国妈妈的朋友在线播放| 国产原创中文字幕| 日韩av片免费播放| 韩国三级视频网站| 久久国产影院| 999久久66久6只有精品| 九九干| 九九免费精品视频| 国产91素人搭讪系列天堂| 青青久久国产成人免费网站| 国产伦精品一区三区视频| 99久久精品国产麻豆| 日韩在线观看免费| 夜夜操天天爽| 日韩中文字幕一区二区不卡| 日本免费看视频| 可以在线看黄的网站| 国产福利免费观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品久久久久久综合网| 九九九网站| 成人免费观看网欧美片| 亚洲女初尝黑人巨高清在线观看| 亚洲爆爽| 日韩av片免费播放| 午夜欧美成人久久久久久| 亚洲爆爽| 国产一区国产二区国产三区| 精品美女| 九九久久国产精品| 国产伦精品一区二区三区无广告 | 国产一级强片在线观看| 欧美激情中文字幕一区二区| 九九久久国产精品| 在线观看成人网 | 国产视频一区二区在线播放| 精品国产一区二区三区国产馆| 国产网站在线| 精品视频免费在线| 麻豆网站在线看| 美女免费毛片| 国产不卡在线观看视频| 免费毛片播放| 99久久精品国产国产毛片| 午夜精品国产自在现线拍| 成人免费福利片在线观看| 精品国产一区二区三区国产馆| 成人a大片高清在线观看| 尤物视频网站在线| 亚洲女人国产香蕉久久精品| 免费的黄视频| 国产视频久久久久| 韩国三级视频网站| 黄色免费网站在线| 中文字幕一区二区三区精彩视频| 精品国产一级毛片| 美女免费精品高清毛片在线视 | 国产不卡高清| 日本特黄特色aa大片免费| 黄视频网站在线观看| 日韩专区在线播放| 高清一级片| 青青久在线视频| 亚洲爆爽| 精品久久久久久免费影院| 精品久久久久久免费影院| 久久久成人影院| 免费一级片在线观看| 日韩在线观看视频黄| 国产一区二区精品| 99久久网站| 国产不卡在线播放| 欧美激情一区二区三区视频 | 国产麻豆精品免费视频| 精品国产亚一区二区三区| 日韩免费片| 精品国产一区二区三区久久久狼| 色综合久久天天综合观看| 天天色色色| 色综合久久天天综线观看| 亚洲 欧美 91| 欧美激情一区二区三区在线 | 韩国三级视频网站| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日日夜夜婷婷| 久草免费在线色站| 高清一级片| 国产成人精品影视| 九九久久国产精品| 99热热久久| 欧美另类videosbestsex久久| 亚久久伊人精品青青草原2020| 欧美大片一区| 精品久久久久久中文字幕一区 | 国产一级生活片| 日本免费乱理伦片在线观看2018| 日韩综合| 色综合久久天天综合| 欧美a免费| 精品国产一区二区三区久久久狼| 一级女性全黄久久生活片| 亚欧视频在线| 四虎论坛| 国产不卡在线观看视频| 欧美另类videosbestsex视频| 日韩欧美一及在线播放| 999久久狠狠免费精品| 一本伊大人香蕉高清在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日本在线不卡免费视频一区| 国产一区二区精品在线观看|