下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
專項(xiàng)代碼1常見大題代碼合輯插入排序(通過鏈表實(shí)現(xiàn))原理:第一步:先創(chuàng)建一個(gè)只有一個(gè)元素的鏈表。第二步:依次生成節(jié)點(diǎn),再將節(jié)點(diǎn)放置到鏈表中指定位置。第三步:輸出鏈表節(jié)點(diǎn)。importrandom#插入排序(鏈表實(shí)現(xiàn))[678,668,267,440,795]ls=[]#鏈表ls[0]是值,ls[1]是指針v=[random.randint(1,1000)foriinrange(5)]#待排序的數(shù)ls.append([v.pop(0),-1])#將第一個(gè)節(jié)點(diǎn)放入head=0p=q=0whilelen(v)!=0:p=q=headwhilep!=-1andls[p][0]>v[0]:q=pp=ls[p][1]ifp!=head:#不放在鏈表頭上ls.append([v.pop(0),ls[q][1]])ls[q][1]=len(ls)-1else:#放在鏈表頭上ls.append([v.pop(0),head])head=len(ls)-1p=headwhilep!=-1:print(ls[p][0])p=ls[p][1]循環(huán)隊(duì)列(通過鏈表實(shí)現(xiàn))原理:入隊(duì):將節(jié)點(diǎn)添加到鏈表尾部(因?yàn)殛?duì)列從尾部進(jìn)入)出隊(duì):刪除當(dāng)前頭節(jié)點(diǎn)(因?yàn)殛?duì)列出隊(duì)是從頭部出隊(duì))importrandom#循環(huán)隊(duì)列功能(鏈表實(shí)現(xiàn))ls=[]#鏈表ls[0]是值,ls[1]是指針head=0p=q=0foriinrange(1,6):#生成5個(gè)值的隊(duì)列l(wèi)s.append([i-1,i])ls[len(ls)-1][1]=0#將隊(duì)列最后一個(gè)指向第一個(gè)#出隊(duì)(出隊(duì)完成后還是一個(gè)圈)p=headwhilels[p][1]!=head:#找到最后一個(gè)節(jié)點(diǎn)p=ls[p][1]head=ls[head][1]ls[p][1]=head#入隊(duì)p=headwhilels[p][1]!=head:p=ls[p][1]ls.append([7,ls[p][1]])ls[p][1]=len(ls)-1數(shù)組插入(通過二分實(shí)現(xiàn))將ls數(shù)組中的值,插入到ls2中指定位置,插入結(jié)束了ls2中的值依然有序原理:第一步:將原始值直接排序第二步:通過對(duì)分查找法查找到對(duì)應(yīng)的值插入的位置第三步:插入值importrandomls=[random.randint(1,100)foriinrange(5)]ls2=[random.randint(1,100)foriinrange(10)]ls.sort()ls2.sort()forkinls:i,j,m=0,len(ls2)-1,0whilei<=j:m=(i+j)//2ifk<ls2[m]:j=m-1else:i=m+1ls2.insert(i,k)#插入到數(shù)組中指定位置。第一個(gè)參數(shù)是位置第二個(gè)參數(shù)是值print(ls2)插入排序(for循環(huán)版本)importrandomn=5a=[random.randint(1,100)foriinrange(n)]#生成隨機(jī)數(shù)foriinrange(n):key=a[i]forjinrange(i-1,-2,-1):ifkey>=a[j]:breakelse:a[j+1]=a[j]a[j+1]=keyprint(a)[16,65,2,33,11]計(jì)數(shù)排序(通過雙重循環(huán)實(shí)現(xiàn))importrandomn=5a=[random.randint(1,100)foriinrange(n)]#生成隨機(jī)數(shù)[82,43,60,27,30]ls=[0]*nforiinrange(n):forjinrange(n):ifa[i]<a[j]:ls[i]+=1print(a)so=[]k=0whilelen(so)!=len(a):ifls[k]==max(ls):so.append(a[k])ls[k]=-1k=(k+1)%len(a)print(so)#排序后的結(jié)果foriinrange(len(ls)):ifls[i]==len(ls)-1:print("最小值是",a[i])ifls[i]==0:print("最大值是",a[i])快速排序(遞歸版本)defpartition(arr,low,high):i=(low-1)pivot=arr[high]forjinrange(low,high):ifarr[j]<=pivot:i=i+1arr[i],arr[j]=arr[j],arr[i]arr[i+1],arr[high]=arr[high],arr[i+1]returni+1defquickSort(arr,low,high):iflow<high:pi=partition(arr,low,high)quickSort(arr,low,pi-1)quickSo
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 成長在母校模板
- 勘探開發(fā)合同范本
- 2024年度水稻訂購協(xié)議范本
- 父母買房的合同范本
- 合同范本掙錢
- 2024年定制機(jī)床購銷協(xié)議模板
- 河南省信用社擔(dān)保合同范本
- 2024年P(guān)IE工程師培訓(xùn)教程:網(wǎng)絡(luò)安全防護(hù)
- 2024室內(nèi)裝修協(xié)議補(bǔ)充條款示例
- 研究生開題答辯報(bào)告模板
- 瓶裝水銷售方案
- 房產(chǎn)背戶協(xié)議
- 婦科人工流產(chǎn)女性落實(shí)高效避孕措施依從性低原因分析魚骨圖柏拉圖對(duì)策擬定
- 外陰陰道炎癥
- 壓力容器及壓力管道課件
- 部編版小學(xué)語文六年級(jí)上冊《童年》閱讀測試題及答案(全冊)
- 山東省濟(jì)南市歷城區(qū)2023-2024學(xué)年五年級(jí)上學(xué)期期中數(shù)學(xué)試卷
- 基本消防知識(shí)考試題庫200題(通用版)
- 讀后續(xù)寫人與動(dòng)物-天使狗狗的守護(hù)講義 高三英語作文復(fù)習(xí)寫作專項(xiàng)
- 課件大班科學(xué)活動(dòng)《有趣的影子》
- 監(jiān)控施工方案四篇
評(píng)論
0/150
提交評(píng)論