




下載本文檔
版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 小麥加工資源增值策略考核試卷
- 土木工程建筑排水系統(tǒng)施工考核試卷
- 2017社保培訓(xùn)課件
- 孔樁勞務(wù)合同范本
- 民宅鋪面出售合同范本
- 碼頭設(shè)備采購合同范本
- 購買國外技術(shù)合同范本
- 熱水買賣合同范本
- led燈改造合同范本
- 寵物寄養(yǎng)服務(wù)中動(dòng)物健康保證協(xié)議
- 22陳涉世家 司馬遷 公開課一等獎(jiǎng)創(chuàng)新教學(xué)設(shè)計(jì) 度部編版初中語文九年級(jí)下冊(cè)
- 2021年飽和蒸汽及過熱蒸汽焓值表
- 《抗戰(zhàn)中的英雄人物》課件
- 外墻真石漆施工方案
- 森林防火安全生產(chǎn)工作
- 《服裝市場(chǎng)營銷》課件
- 網(wǎng)絡(luò)安全風(fēng)險(xiǎn)評(píng)估報(bào)告模板
- 什么是法律談判課件
- 成考教材-數(shù)學(xué)教程(文史財(cái)經(jīng)類)
- 保安服務(wù)管理制度范文
- 汽車行業(yè)維修記錄管理制度
評(píng)論
0/150
提交評(píng)論