




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第十四章(排序)考綱中的排序包括冒泡排序,選擇排序。但是在實際解題中還會碰到其他排序,例如桶排序、插入排序、選擇排序、索引排序及冒泡排序的優(yōu)化。本文將針對冒泡、選擇、插入、選擇排序、桶排序、索引排序及冒泡排序優(yōu)化進行分析。升序排:從小到大排序,降序排:從大到小排序冒泡排序冒泡排序算法是把較小的元素往前調(diào)或者把較大的元素往后調(diào)。這種方法主要是通過對相鄰兩個元素進行大小的比較,根據(jù)比較結(jié)果和算法規(guī)則對該二元素的位置進行交換,這樣逐個依次進行比較和交換,就能達到排序目的。冒泡排序比較次數(shù)(n*(n-1))/2有如下公共代碼:importrandomls=[]n=5foriinrange(n):ls.append(random.randint(10,100))foriinrange(n-1):forjinrange(n-1,i,-1):ifls[j]>ls[j-1]:ls[j]=ls[j]+ls[j-1]ls[j-1]=ls[j]-ls[j-1]ls[j]=ls[j]-ls[j-1]降序排(從后往前冒泡)foriinrange(n-1):forjinrange(n-1,i,-1):ifls[j]<ls[j-1]:ls[j]=ls[j]+ls[j-1]ls[j-1]=ls[j]-ls[j-1]ls[j]=ls[j]-ls[j-1]升序排(從后往前冒泡) 表1.1foriinrange(n-1):forjinrange(0,n-i-1):ifls[j]>ls[j+1]:ls[j]=ls[j]+ls[j+1]ls[j+1]=ls[j]-ls[j+1]ls[j]=ls[j]-ls[j+1]升序排(從前往后冒泡)foriinrange(n-1):forjinrange(1,n-i):ifls[j]>ls[j-1]:ls[j]=ls[j]+ls[j-1]ls[j-1]=ls[j]-ls[j-1]ls[j]=ls[j]-ls[j-1]降序排(從前往后冒泡)foriinrange(n-1):flag=Falseforjinrange(n-1,i,-1):ifls[j]>ls[j-1]:ls[j]=ls[j]+ls[j-1]ls[j-1]=ls[j]-ls[j-1]ls[j]=ls[j]-ls[j-1]Flag=TrueIfflag==False:break冒泡優(yōu)化1k=n-1last=0foriinrange(n-1):flag=Trueforjinrange(k):ifls[j]>ls[j+1]:ls[j]=ls[j]+ls[j+1]ls[j+1]=ls[j]-ls[j+1]ls[j]=ls[j]-ls[j+1]last=jflag=Falsek=lastifflag:break冒泡優(yōu)化2 表1.2選擇排序選擇排序是給每個位置選擇當前元素最小的,比如給第一個位置選擇最小的,在剩余元素里面給第二個元素選擇第二小的,依次類推,直到第n-1個元素,第n個元素不用選擇了。有如下公共代碼:importrandomls=[]n=5foriinrange(n):ls.append(random.randint(10,100))foriinrange(n-1):k=iforjinrange(i+1,n):ifls[j]<ls[k]:k=jifk!=i:ls[k],ls[i]=ls[i],ls[k]選擇排序?qū)懛?foriinrange(n-1):forjinrange(i+1,n):ifls[i]>ls[j]:ls[i],ls[j]=ls[j],ls[i]選擇排序?qū)懛?表1.3桶排序桶排序(Bucketsort)或所謂的箱排序,是一個排序算法,工作的原理是將數(shù)組分到有限數(shù)量的桶子里。每個桶子再個別排序(有可能再使用別的排序算法或是以遞歸方式繼續(xù)使用桶排序進行排序)n=10ls=[random.randint(1,100)foriinrange(n)]#生成隨機數(shù)bucket=[0]*101#新建一個范圍在[0,100]之間的桶foriinls:#入桶bucket[i]+=1foriinrange(1,100):#出桶forjinrange(bucket[i]):print(i,end=",")插入排序插入排序,一般也被稱為直接插入排序。對于少量元素的排序,它是一個有效的算法。插入排序是一種最簡單的排序方法,它的基本思想是將一個記錄插入到已經(jīng)排好序的有序表中,從而一個新的、記錄數(shù)增1的有序表。在其實現(xiàn)過程使用雙層循環(huán),外層循環(huán)對除了第一個元素之外的所有元素,內(nèi)層循環(huán)對當前元素前面有序表進行待插入位置查找,并進行移動importrandomj=0n=5a=[random.randint(1,100)foriinrange(n)]#生成隨機數(shù)foriinrange(0,n):key=a[i]j=i-1whilej>=0andkey<a[j]:a[j+1]=a[j]j=j-1a[j+1]=key索引排序索引排序,是基于冒泡排序法的一種優(yōu)化算法,算法核心是:用一個數(shù)組元素的值做另一個數(shù)組元素的下標,然后交換下標。例如a[b[1]]<a[b[2]]:t=b[1]:b[1]=b[2]:b[2]=t。代碼如下:importrandomn=10ls=[random.randint(1,100)foriinrange(n)]#生成隨機數(shù)xb=[iforiinrange(n)]fori
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度電子商務(wù)平臺客服人員派遣合同
- 2025年度果園租賃與果樹栽培技術(shù)培訓合同
- 二零二五年度摩托車轉(zhuǎn)讓過戶及駕駛培訓合同
- 二零二五年度跨境貿(mào)易合同中對發(fā)票種類及開具要求的約定
- 幼兒園托管協(xié)議書(二零二五年度)營養(yǎng)膳食保障合同
- 二零二五年度老板與廚師長合作推進特色餐飲品牌連鎖發(fā)展合同
- 二零二五年度小學生視力篩查與視力保護合作合同
- 二零二五年度物流金融運輸合同匯編與風險分擔機制
- 二零二五年度家庭旅游規(guī)劃與陪同服務(wù)合同
- 企業(yè)經(jīng)營困難報告(3篇)
- 綜合應(yīng)用能力事業(yè)單位考試(綜合管理類A類)試題及解答參考
- 阿爾茲海默病的家庭護理
- bim技術(shù)課件教學課件
- 腹水形成的原因及治療
- 單晶爐車間安全培訓
- 高中地理必修第一冊期末試卷及答案-中圖版-2024-2025學年
- 護理核心制度測試題+參考答案
- 機械制造技術(shù)基礎(chǔ)(課程課件完整版)
- 《2023版CSCO卵巢癌診療指南》解讀課件
- 【醫(yī)院藥品管理系統(tǒng)探析與設(shè)計(論文)10000字】
- 螺旋體病梅毒課件
評論
0/150
提交評論