程序設(shè)計(jì)排序算法分析_第1頁
已閱讀1頁,還剩5頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  程序設(shè)計(jì)排序算法分析</p><p>  摘 要:排序算法是計(jì)算機(jī)程序設(shè)計(jì)的一個(gè)重要內(nèi)容,對排序算法的分析與研究具有廣泛的應(yīng)用價(jià)值。本文介紹了常見的排序算法,并通過對比分析,對各種排序算法從算法評價(jià)角度給出了綜合評價(jià)。 </p><p>  關(guān)鍵詞:排序算法;內(nèi)部排序;對比分析;算法評價(jià) </p><p>  排序是程序設(shè)計(jì)的常見問題,選擇合理

2、高效的排序算法是數(shù)據(jù)處理的最重要的研究問題之一。排序算法的功能是將一個(gè)由一組數(shù)據(jù)元素或記錄組成的無序序列,重新排列成一個(gè)按關(guān)鍵字有序的序列[1]。有序序列可有效地提高記錄的查找效率。 </p><p><b>  1 排序算法分類 </b></p><p><b>  1.1 內(nèi)部排序 </b></p><p>  內(nèi)部排

3、序是指待排序列完全存放在內(nèi)存中所進(jìn)行的排序過程,適合規(guī)模不太大的數(shù)據(jù)元素序列。內(nèi)部排序可分為五類: 插入排序、交換排序、選擇排序、歸并排序和分配排序。 </p><p><b>  1.2 外部排序 </b></p><p>  外部排序是指待排序的序列無法一次裝入內(nèi)存,需要在內(nèi)存和外存之間進(jìn)行多次數(shù)據(jù)交換,從而達(dá)到對序列中全部數(shù)據(jù)元素的排序。外部排序可將待排序序列分

4、解成幾段能夠一次性裝人內(nèi)存的待排序部分,然后對每一小段采用內(nèi)部排序,再對已經(jīng)排序的各子段進(jìn)行歸并排序。即外部排序轉(zhuǎn)化為內(nèi)部排序。因此需對內(nèi)部排序進(jìn)行更深入的研究分析。 </p><p>  2 常見的排序算法 </p><p><b>  2.1 插入排序 </b></p><p>  插入排序每次將一個(gè)待排序的數(shù)據(jù)元素,插入到前面已經(jīng)排好序的

5、序列中適當(dāng)位置,使序列依然有序,直到待排序數(shù)據(jù)元素全部插入完為止。插入排序包括直接插入排序、折半插入排序和希爾排序。 </p><p> ?。?)直接插入排序:將無序序列中的第一個(gè)數(shù)據(jù)元素依次插入到有序序列的合適位置,使有序序列仍然有序。 </p><p> ?。?)折半插入排序:在有序序列中用折半法(二分法)查找待插入數(shù)據(jù)元素的位置。將處于有序序列中間位置數(shù)據(jù)元素的關(guān)鍵字和待排序數(shù)據(jù)元素

6、的關(guān)鍵字比較,便把可插入的區(qū)間縮小一半,故稱為折半。折半插入排序僅減少了關(guān)鍵字間的比較次數(shù),但數(shù)據(jù)元素的移動(dòng)次數(shù)不變。 </p><p> ?。?)希爾排序:先 取一個(gè)小于n的整數(shù)d1作為第一個(gè)增量,把文件的全部記錄分成d1組。所有距離為d1的倍數(shù)的記錄放在同一組中。先在各組內(nèi)進(jìn)行直接插入排序,然后取第二個(gè)增量d2<d1重復(fù)上述的分組和排序,直到所取的增量dt=1,即所有記錄放在同一組中進(jìn)行直接插入排序?yàn)橹?/p>

7、。 </p><p><b>  2.2 交換排序 </b></p><p>  交換排序是指通過在數(shù)據(jù)元素之間互相交換逆序元素而進(jìn)行的排序。交換排序包括冒泡排序和快速排序。 </p><p>  (1)冒泡排序:通過將相鄰的數(shù)據(jù)元素進(jìn)行比較,若逆序則交換,逐步將無序序列處理成為有序序列。每一趟交換排序都會(huì)增加一個(gè)元素到有序區(qū),整個(gè)冒泡排序過程

8、最多需要進(jìn)行n-1趟排序。 </p><p>  (2)快速排序:通過一趟排序?qū)⒋判虻臄?shù)據(jù)元素分割成獨(dú)立的兩部分,其中一部分?jǐn)?shù)據(jù)元素的關(guān)鍵字均比另一部分?jǐn)?shù)據(jù)元素的關(guān)鍵字小。則可分別對這兩部分元素繼續(xù)進(jìn)行排序,以達(dá)到整個(gè)序列有序。 </p><p><b>  2.3 選擇排序 </b></p><p>  選擇排序是每一趟從待排序的數(shù)據(jù)元素中

9、選出關(guān)鍵字最小(或最大)的一個(gè)元素,插入已排序序列的最后,直到n個(gè)數(shù)據(jù)元素全部插入已排序序列中。選擇排序包括簡單選擇排序、樹型選擇排序和堆排序。 </p><p> ?。?)簡單選擇排序:從無序的序列中選取一個(gè)關(guān)鍵字最小的數(shù)據(jù)元素存放到有序序列中指定的位置。 </p><p> ?。?)樹型選擇排序:又稱為錦標(biāo)賽排序,是按錦標(biāo)賽思想進(jìn)行選擇排序的方法。先對n個(gè)數(shù)據(jù)元素的關(guān)鍵字進(jìn)行兩兩比較,

10、然后在其中的(n/2)個(gè)較小者間再進(jìn)行兩兩比較,如此往復(fù),直至選出最小關(guān)鍵字的數(shù)據(jù)元素為止。這個(gè)過程可用一棵n個(gè)結(jié)點(diǎn)的完全二叉樹來表示。 </p><p> ?。?)堆排序:堆是滿足如下性質(zhì)的完全二叉樹:樹中任一非葉子結(jié)點(diǎn)的關(guān)鍵字均大于等于其孩子結(jié)點(diǎn)的關(guān)鍵字。這種堆中根結(jié)點(diǎn)(稱為堆頂)的關(guān)鍵字最小,稱之為小根堆;反之,則稱之為大根堆。堆排序的算法是:將當(dāng)前無序區(qū)調(diào)整為一個(gè)大根堆(或小根堆),選取關(guān)鍵字最大(或最小

11、)的堆頂記錄,將它和無序區(qū)中的最后一個(gè)記錄交換。這樣,正好和直接選擇排序相反,有序區(qū)是在原記錄區(qū)的尾部形成并逐步向前擴(kuò)大到整個(gè)記錄區(qū)。 </p><p><b>  2.4 歸并排序 </b></p><p>  歸并排序是將兩個(gè)或兩個(gè)以上的有序序列合并成一個(gè)新的有序序列。歸并排序包括二路歸并排序和多路歸并排序。 </p><p>  (1)二

12、路歸并排序:將兩個(gè)有序序列合并成一個(gè)新的有序序列。先從兩個(gè)有序序列中分別取第一個(gè)數(shù)據(jù)元素比較,關(guān)鍵字?。ɑ虼螅┑臄?shù)據(jù)元素排入新的有序序列,同時(shí)在對應(yīng)原序列中刪除該數(shù)據(jù)元素;然后再從兩個(gè)有序序列中分別取第一個(gè)數(shù)據(jù)元素比較,如此循環(huán);當(dāng)有一個(gè)序列為空時(shí),則直接將另一個(gè)序列的數(shù)據(jù)元素依次取出即可。 </p><p> ?。?)多路歸并排序:將多個(gè)有序序列合并成一個(gè)新的有序序列。通常用于外部排序。 </p>

13、<p><b>  2.5 分配排序 </b></p><p>  分配排序的排序過程無須比較關(guān)鍵字,而是通過分配和收集過程來實(shí)現(xiàn)排序。分配排序包括箱排序和基數(shù)排序。 </p><p><b> ?。?)箱排序。 </b></p><p>  箱排序是設(shè)置若干個(gè)箱子,依次掃描待排序的數(shù)據(jù)元素R[0],R[1],

14、…,R[n-1],把關(guān)鍵字等于k的記錄全都裝入到第k個(gè)箱子里(分配),然后按序號依次將各非空的箱子首尾連接起來(收集)。 </p><p><b> ?。?)基數(shù)排序 </b></p><p>  基數(shù)排序的算法是:一個(gè)邏輯關(guān)鍵字可以看成由若干個(gè)關(guān)鍵字復(fù)合而成的,可把每個(gè)排序關(guān)鍵字看成是一個(gè)d元組,即例如由關(guān)鍵字K由d個(gè)關(guān)鍵字(K0,K1,…,Kd-1)組成,排序時(shí)先

15、按K0的值從小到大(或從大到?。⒂涗浄峙涞絩個(gè)盒子中,然后依次收集這些記錄,再按K1的值分配到r個(gè)盒子中,如此反復(fù),直到按Kd-1的值分配后收集起來的序列,便是完全排序的狀態(tài),其中r稱為基數(shù)。基數(shù)的選擇和關(guān)鍵字的分解法因關(guān)鍵字的類型而異?;鶖?shù)排序分為最高位優(yōu)先法和最低位優(yōu)先法。 </p><p><b>  3 算法評價(jià) </b></p><p><b>

16、  3.1 穩(wěn)定性 </b></p><p>  在待排序的序列中,若存在元素值相同的記錄,經(jīng)過排序后,這些元素的相對次序不變,那么此算法為穩(wěn)定的。冒泡排序、插入排序、歸并排序和基數(shù)排序是穩(wěn)定的排序算法;選擇排序、快速排序、希爾排序、堆排序是不穩(wěn)定的排序算法。 </p><p>  3.2 時(shí)間復(fù)雜度 </p><p>  時(shí)間復(fù)雜度是指執(zhí)行算法所需要的

17、計(jì)算工作量[3]。按平均情況下時(shí)間復(fù)雜度將排序分為四類:(1) 平方階(O(n2))排序:一般稱為簡單排序,如冒泡排序、簡單選擇排序和直接插入排序。(2) 線性對數(shù)階O(nlgn)排序:如快速排序、歸并排序和堆排序。(3) O(n1+£)階排序:£是介于0和1之間的常數(shù),即0<£<1,如希爾排序。(4)線性階(O(n))排序:如箱排序和基數(shù)排序。 </p><p>  3.3 空間復(fù)雜度 </p

18、><p>  空間性能是排序所需輔助空間大小,所有簡單排序和堆排序都是O (1);歸并排序和基數(shù)排序所需輔助空間最多,為O(n)。 </p><p><b>  4 結(jié)論 </b></p><p>  排序算法有很多,具體情況中使用哪一種算法很重要。為了選擇合適的算法,應(yīng)順序考慮以下標(biāo)準(zhǔn): 執(zhí)行時(shí)間 ,存儲(chǔ)空間,編程工作量。數(shù)據(jù)量較小時(shí),執(zhí)行時(shí)間

19、和存儲(chǔ)空間差別不大,主要考慮編程工作量;當(dāng)數(shù)據(jù)量大時(shí), 執(zhí)行時(shí)間為首要。相對來說,簡單排序中直接插入排序最好,快速排序最快,當(dāng)序列為正序時(shí),直接插入排序和冒泡排序都是較好選擇。 </p><p><b>  參考文獻(xiàn) </b></p><p>  [1] 劉冬莉, 徐立輝. 大學(xué)計(jì)算機(jī)基礎(chǔ)教程[M]. 北京:清華大學(xué)出版社, 2011. </p><

20、;p>  [2] 嚴(yán)蔚敏, 吳偉民. 數(shù)據(jù)結(jié)構(gòu)(C語言版)[M] . 北京:清華大學(xué)出版社, 2002. </p><p>  [3] 劉模群. 排序算法時(shí)間復(fù)雜度研究[J]. 軟件導(dǎo)刊, 2012(6). </p><p><b>  作者簡介 </b></p><p>  馮毅宏,女,講師, 主要從事非線性動(dòng)力系統(tǒng)圖形化和計(jì)算機(jī)教育研

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論