python列表與列表算法詳解(2)
1. 案例【三酷貓列表記賬】
操作需求:
(1)用列表對(duì)象記錄三酷貓每天釣魚(yú)的種類(lèi)和數(shù)量
(2)統(tǒng)計(jì)三酷貓所釣水產(chǎn)品的總數(shù)量和預(yù)計(jì)收獲金額
(3)打印財(cái)務(wù)報(bào)表一張。
#三酷貓列表記賬 nums = 0 #統(tǒng)計(jì)數(shù)量變量 amount = 0 #統(tǒng)計(jì)金額數(shù)量 i = 0 #循環(huán)控制變量 fish_record = ['1月1日','鯽魚(yú)',18,10.5,'1月1日','鯉魚(yú)',8,6.2,'1月1日','鰱魚(yú)',7,4.7,'1月2日','草魚(yú)',2,7.2,'1月2日','鯽魚(yú)',3,12,'1月2日','黑魚(yú)',6,15,'1月3日','烏龜',1,71,'1月3日','鯽魚(yú)',1,9.8] print('釣魚(yú)日期名稱(chēng)數(shù)量單價(jià)(元)') print('-'*30) while i<len(fish_record): nums = nums + fish_record[i+2] #累計(jì)數(shù)量 amount = amount + fish_record[i+2]*fish_record[i+3] #累計(jì)金額 print('%s,%s,%.2f,%.2f'%(fish_record[i],fish_record[i+1],fish_record[i+2],fish_record[i+3])) i += 4 #循環(huán)控制 print('-'*30) print(' 總數(shù):%d,總金額%.2f元'%(nums,amount))
結(jié)果:
2. 案例【三酷貓冒泡法排序】
冒泡排序:通過(guò)不斷調(diào)整排序元素的次序,實(shí)現(xiàn)集合元素從小到大的排序過(guò)程。
** 冒泡排序過(guò)程**
(1)取左邊第一個(gè)元素,然后與后面的元素進(jìn)行比較,若發(fā)現(xiàn)后面的元素比第一個(gè)元素小,則交換位置,繼續(xù)往后比較,一直比較調(diào)整到最后一個(gè)元素,該元素為最大的元素。
(2)再取第一個(gè)元素,根據(jù)第一步一次比較、調(diào)整,直到倒數(shù)第二個(gè)停止;其他元素都依次循環(huán)比較、調(diào)整,每次循環(huán)多減一次,n-m(n為集合長(zhǎng)度,m為每循環(huán)一次,增加一次,m從0 開(kāi)始)。
(3)所有元素比較、調(diào)整完畢,完成集合元素增序排序。
冒泡法排序示意圖
fish_records = [18,8,7,2,3,6,1,1] i = 0 #循環(huán)控制變量 compare = 0 #比較元素初始值 fish_len = len(fish_records) #獲取列表長(zhǎng)度 while i<fish_len: j = 1 #循環(huán)控制變量 while j<fish_len-i: #循環(huán)一遍,長(zhǎng)度減1 if fish_records[j-1]>fish_records[j]: #比較前后兩個(gè)元素的大小 compare = fish_records[j-1] #前一個(gè)大的放到臨時(shí)比較變量里 fish_records[j-1] = fish_records[j] #把小的元素放到前面 fish_records[j] = compare #把臨時(shí)變量里的大元素放到后面 j += 1 #內(nèi)循環(huán)控制變量+1 i += 1 #外循環(huán)控制變量+1 print(fish_records)
結(jié)果:
3. 案例【三酷貓二分法查找】
二分法查找:指在有序集合里,對(duì)集合下標(biāo)范圍通過(guò)取中位法獲取對(duì)應(yīng)的元素值,進(jìn)行疊代查找比較,直至找到所需要的元素。如set1[1…N],(1…N為集合元素下標(biāo)順序值)先取一個(gè)下標(biāo)中位值K1= (1+N)/2,獲取set1[K1]值與查找對(duì)象M進(jìn)行比較。若set1[K1]等于M,則查找成功,返回查找位置;若set1[K1]小于M,則在[K+1,N]區(qū)間里再取中位值,進(jìn)行查找比較;若set1[K1]大于M,則在[1,K-1]區(qū)間里再取中位值,進(jìn)行查找比較。通過(guò)不斷縮小查找區(qū)間范圍,可以快速獲取所需要查找的值。
fish_records = [1,1,2,3,6,7,8,18] low = 0 #查找范圍下界 high = len(fish_records)-1 #查找范圍上界 find_value = 7 #要尋找的值 find_OK = False #是否找到標(biāo)志,True為找到 i = 1 while low<=high: middle = int((low+high)/2) #用int取整數(shù),避免浮點(diǎn)數(shù)問(wèn)題的發(fā)生 if find_value == fish_records[middle]: #找到時(shí) find_OK = True #設(shè)置標(biāo)志為T(mén)rue break elif find_value>fish_records[middle]: #沒(méi)有找到,要找的值范圍大于中位值時(shí) low = middle+1 #范圍在middle+1和high之間 elif find_value<fish_records[middle]: #沒(méi)有找到,要找的值范圍小于中間值時(shí) high = middle-1 #范圍在low和middle-1之間 i += 1 if find_OK: print('%d在列表下標(biāo)%d處,找了%d次。'%(find_value,middle,i)) else: print('要找的數(shù)%d沒(méi)有!找了%d次。'%(find_value,i))
結(jié)果:
代碼運(yùn)算示意圖:
總結(jié)
本篇文章就到這里了,希望能給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
利用Python將時(shí)間或時(shí)間間隔轉(zhuǎn)為ISO 8601格式方法示例
國(guó)際標(biāo)準(zhǔn)化組織的國(guó)際標(biāo)準(zhǔn)ISO8601是日期和時(shí)間的表示方法,全稱(chēng)為《數(shù)據(jù)存儲(chǔ)和交換形式·信息交換·日期和時(shí)間的表示方法》,下面這篇文章主要給大家介紹了關(guān)于利用Python將時(shí)間或時(shí)間間隔轉(zhuǎn)為ISO 8601格式的相關(guān)資料,需要的朋友可以參考下。2017-09-09對(duì)python修改xml文件的節(jié)點(diǎn)值方法詳解
今天小編就為大家分享一篇對(duì)python修改xml文件的節(jié)點(diǎn)值方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12Python3+SQLAlchemy+Sqlite3實(shí)現(xiàn)ORM教程
這篇文章主要介紹了Python3+SQLAlchemy+Sqlite3實(shí)現(xiàn)ORM教程,需要的朋友可以參考下2021-02-02Python列表原理與用法詳解【創(chuàng)建、元素增加、刪除、訪問(wèn)、計(jì)數(shù)、切片、遍歷等】
這篇文章主要介紹了Python列表原理與用法,結(jié)合實(shí)例形式詳細(xì)分析了Python列表的創(chuàng)建、元素增加、刪除、訪問(wèn)、計(jì)數(shù)、切片、遍歷、排序等各種常見(jiàn)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2019-10-10PyQtGraph在pyqt中的應(yīng)用及安裝過(guò)程
這篇文章主要介紹了PyQtGraph在pyqt中的應(yīng)用,文中給大家介紹了pyqtgraph的主要用途及PyQtGraph的安裝過(guò)程,需要的朋友可以參考下2019-08-08Jupyter notebook 更改文件打開(kāi)的默認(rèn)路徑操作
這篇文章主要介紹了Jupyter notebook 更改文件打開(kāi)的默認(rèn)路徑操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-05-05Python3爬蟲(chóng)中Selenium的用法詳解
在本篇內(nèi)容里小編給大家分享了關(guān)于Python3爬蟲(chóng)中Selenium的用法詳解內(nèi)容,需要的朋友們可以參考下。2020-07-07python隨機(jī)生成庫(kù)faker庫(kù)api實(shí)例詳解
今天小編就為大家分享一篇python隨機(jī)生成庫(kù)faker庫(kù)api實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11python學(xué)習(xí)--使用QQ郵箱發(fā)送郵件代碼實(shí)例
這篇文章主要介紹了python使用QQ郵箱發(fā)送郵件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04