53數(shù)據(jù)排序-選擇課件高二上學(xué)期選擇性必修1《數(shù)據(jù)與數(shù)據(jù)結(jié)構(gòu)》第五章浙教版_第1頁(yè)
53數(shù)據(jù)排序-選擇課件高二上學(xué)期選擇性必修1《數(shù)據(jù)與數(shù)據(jù)結(jié)構(gòu)》第五章浙教版_第2頁(yè)
53數(shù)據(jù)排序-選擇課件高二上學(xué)期選擇性必修1《數(shù)據(jù)與數(shù)據(jù)結(jié)構(gòu)》第五章浙教版_第3頁(yè)
53數(shù)據(jù)排序-選擇課件高二上學(xué)期選擇性必修1《數(shù)據(jù)與數(shù)據(jù)結(jié)構(gòu)》第五章浙教版_第4頁(yè)
53數(shù)據(jù)排序-選擇課件高二上學(xué)期選擇性必修1《數(shù)據(jù)與數(shù)據(jù)結(jié)構(gòu)》第五章浙教版_第5頁(yè)
已閱讀5頁(yè),還剩8頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

5.5數(shù)據(jù)排序–選擇排序(升序?yàn)槔稊?shù)據(jù)與數(shù)據(jù)結(jié)構(gòu)》一、選擇排序基本思想:是對(duì)參加排序的數(shù)組中所有元素中找出最?。ɑ蜃畲螅┑臄?shù)據(jù),使它與第一個(gè)(或最后一個(gè))元素中的數(shù)據(jù)進(jìn)行相互交換位置。然后在余下的元素中找出最?。ɑ蜃畲螅┑臄?shù)據(jù),與第二個(gè)(或最后第二個(gè))元素中的數(shù)據(jù)交換位置。以此類推,直到所有元素稱為一個(gè)有序的序列。一、選擇排序過(guò)程每趟排序后數(shù)組a的值分別為:第1趟:[1,9,3,8,5,2]第2趟:[1,2,3,8,5,9]第3趟:[1,2,3,8,5,9]第4趟:[1,2,3,5,8,9]第5趟:[1,2,3,5,8,9]一、選擇排序過(guò)程注意:紅色標(biāo)記最小值

綠色標(biāo)記待排序區(qū)間

黃色標(biāo)記有序區(qū)間三、選擇排序和冒泡排序

對(duì)比小結(jié)冒泡排序選擇排序排序遍數(shù)比較次數(shù)交換次數(shù)時(shí)間復(fù)雜度n-1n-1(n-1)*n/2(n-1)*n/2逆序?qū)?shù)量<=n-1O(n2)O(n2)選擇排序的比較次數(shù)與待排序元素的初始狀態(tài)無(wú)關(guān),而交換次數(shù)與待排序元素的初始狀態(tài)有關(guān),當(dāng)待排序元素已經(jīng)有序時(shí),交換

0次,最壞情況下交換n-1次。一、選擇排序程序?qū)崿F(xiàn)(以升序?yàn)槔?i=0;min=?forjinrange(1,?)#依次比較找最小值的下標(biāo)ifa[j]

?

a[min]:#升序排序min=jifmin!=?:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=0;min=0forjinrange(1,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值一、選擇排序程序?qū)崿F(xiàn)(以升序?yàn)槔?i=1;min=?#假設(shè)待排序區(qū)間第一個(gè)元素為擂主forjinrange(?,?)#依次比較找最小值的下標(biāo)ifa[j]

?

a[min]:#升序排序min=jifmin!=?:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=1;min=1#假設(shè)待排序區(qū)間第一個(gè)元素為擂主forjinrange(2,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值一、選擇排序程序?qū)崿F(xiàn)(以升序?yàn)槔?i=2;min=?forjinrange(?,?)#依次比較找最小值的下標(biāo)ifa[j]

<

a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=2;min=2forjinrange(3,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值一、選擇排序程序?qū)崿F(xiàn)(以升序?yàn)槔?i=3;min=?forjinrange(?,?)#依次比較找最小值的下標(biāo)ifa[j]

<

a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=3;min=3forjinrange(4,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值一、選擇排序程序?qū)崿F(xiàn)(以升序?yàn)槔?i=4;min=?forjinrange(?,?)#依次比較找最小值的下標(biāo)ifa[j]

<

a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=4;min=4forjinrange(5,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值一、選擇排序程序?qū)崿F(xiàn)(6個(gè)元素升序?yàn)槔?i=0;min=0#第一趟排序forjinrange(1,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=1;min=1#第二趟排序forjinrange(2,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=2;min=2#第三趟排序forjinrange(3,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=3;min=3#第四趟排序forjinrange(4,6)#依次比較找最小值的下標(biāo)ifa[j]

<a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值i=4;min=?#第五趟排序forjinrange(5,6)#依次比較找最小值的下標(biāo)ifa[j]

<

a[min]:#升序排序min=jifmin!=i:a[min],a[i]=a[i],a[min]

#交換a[min]與a[i]的值n=len(a)

#n個(gè)元素規(guī)模升序排序

做個(gè)筆記寶典P82foriinrange(?)#外循環(huán)表示排序趟次

min=?#假設(shè)待排序區(qū)間第一個(gè)元素為擂主

forjinrange(?,?):#將每個(gè)元素跟當(dāng)前擂主PK

ifa[j]

?

a[min]:#PK成功則更換擂主min=j

#更換擂主ifmin!=i

:a[min],a[i]=a[i],a[min]

#交換n-1ii+1n<二、選擇排序和冒泡排序

程序?qū)Ρ刃〗Y(jié)n=len(a)

#選擇排序

順序掃描foriinrange(n-1)#排序最多n-1趟

min=i#假設(shè)待排序區(qū)間第一個(gè)元素為擂主

forjinrange(i+1,n):#將每個(gè)元素跟當(dāng)前擂主PK

ifa[j]

<

a[min]:#PK成功則更換擂主

升序

min=j

#更換擂主ifmin!=i

:

a[min],a[i]=a[i],a[min]

#交換n=len(a)#冒泡排序

逆序掃描foriinrange(n-1):#排序n-1趟

forjinrange(n-1,i,-1):#從后往前掃描ifa[j-1]>a[j]:#相鄰元素比較

升序

a[j],a[j-1]=a[j-1],a[j]#交換選擇與冒泡排序的最大區(qū)別:選擇排序待排序區(qū)間內(nèi)的元素a[min]能與最左端(或最右端)的元素a[i]發(fā)生交換,冒泡排序是相鄰元素交換。對(duì)比兩段程序,為何選擇排序更高效,主要就是因?yàn)橛衜in變

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論