青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

羅朝輝(飄飄白云)

關注嵌入式操作系統,移動平臺,圖形開發。-->加微博 ^_^

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  85 隨筆 :: 0 文章 :: 169 評論 :: 0 Trackbacks

排序算法之選擇排序   

羅朝輝(http://m.shnenglu.com/kesalin

轉載請注明出處

排序是數據處理中經常使用的一種重要運算,在計算機及其應用系統中,花費在排序上的時間在系統運行時間中占有很大比重,其重要性無需多言。下文將介紹常用的如下排序方法,對它們進行簡單的分析和比較,并提供 C 語言實現。


所謂排序,就是要將一堆記錄,使之按關鍵字遞增(或遞減)次序排列起來。根據排序所采用的策略,可以分為如下五種:

1、插入排序(直接插入排序、希爾排序)

2、交換排序(冒泡排序、快速排序)

3、選擇排序(直接選擇排序、堆排序)

4、歸并排序;

5、桶排序(桶排序,基數排序);


---------------------------------------------------------------------------------


前面講了插入,交換排序,下面接著來講選擇排序。


選擇排序(Selection Sort)的基本思想是:每一趟從待排序的記錄中選出關鍵字最小的記錄,順序放在已排好序的子文件的最后,直到全部記錄排序完畢。


常用的選擇排序方法有直接選擇排序和堆排序。


直接選擇排序

基本思想:將待排序記錄分成有序區和無序區,初始狀態下有序區位空,無序區為整個待排序記錄。每一趟選擇排序就是在無序區中選擇最小(或最大)的記錄,插入到有序區的最后。如此循環直到無序區為空,完成排序。


代碼實現

// 直接選擇排序 // void select_sort(int* array, int length) { assert(array && length >= 0); int i, j, k, temp; for (i = 1; i < length; ++i) { k = i; for (j = i + 1; j < length; ++j) { if (array[j] < array[k]) { k = j; } } if (k != i) { temp = array[i]; array[i] = array[k]; array[k] = temp; } } }


時間復雜度分析:

無論待排序記錄的初始狀態如何,在第 i 趟排序中選出最小關鍵字的記錄,需做 n - i 次比較,因此,總的比較次數為: n * (n - 1) / 2 = 0(n ^ 2),當待排序記錄的初始狀態為正序時,移動次數為 0;當初始狀態為反序時,每趟排序均要執行交換操作,總的移動次數取最大值 3 * (n-1)。所以,直接選擇排序的平均時間復雜度為 0(n ^ 2)。


空間復雜度:

很明顯,0(1)。


補充:

直接選擇排序是一個就地排序,且是非穩定排序。


堆排序

堆的定義:滿足如下約束的 n 個關鍵字序列 Kl,K2,…,K稱為堆,1 ≤ i ≤ n/2,
   (1) k≤ K2i 且 k≤ K2i+1 (小根堆)   或

(2) K≥ K2i 且 k≥ K2i+1 (大根堆)


從定義來看,堆實質上是滿足如下性質的完全二叉樹:樹中任一非葉結點的關鍵字均不大于(或不小于)其左右孩子(若存在的話)結點的關鍵字。堆排序就是充分利用堆這種堆頂記錄要么是最大的要么是最小的有序性質,每次在堆中選擇最大或最小關鍵字完成排序。堆排序也是選擇排序的一種,它比直接選擇排序平均效率要高,因為直接選擇排序,每次比較之后并沒有對比較結果進行保存,導致可能存在重復的比較,而堆則利用其堆性質將比較結果保存在堆中了(非葉子節點的左邊孩子一定不大于或不小于比右邊的孩子)。


堆排序的關鍵就在于將待排序記錄的建立成堆,建好堆之后,將無序區的堆頂記錄(總是無序區的最大或最小)和無序區最后一個記錄交換,交換之后,無序區的最后一個記錄變成有序區的第一個記錄,而無序區新的的堆頂記錄不一定滿足堆性質了,因而需要將無序區調整而堆。如此循環,直到無序區為空,結束排序。


所以堆排序的主要步驟就分三步:

1,建立初始堆;

2,將無序的堆頂記錄與最后一個記錄交換,縮小無序區;

3,將交換之后的無序區調整為堆,重復步驟 2。


代碼實現:

// 篩選法調整堆,除 [low] 之外,[low] 的兩個孩子均已是大根堆 void adjust_heap(int* heap, int low, int high) { assert(heap); #if 1 // 循環實現 int i = low; int j = 2 * i; int temp = heap[i]; while (j <= high) { // 若有兩個孩子,j 為孩子中大的那個的下標 if (j < high && heap[j] < heap[j + 1]) { j = j + 1; } // 已是堆 if (temp >= heap[j]) { break; } // 繼續篩選 else { heap[i] = heap[j]; i = j; j = 2 * i; } } heap[i] = temp; #else // 遞歸實現 int i = low; int j = 2 * i; int temp = heap[i]; if (j >= high) { return; } // 若有兩個孩子,j 為孩子中大的那個的下標 if (j < high && heap[j + 1] > heap[j]) { j = j + 1; } // 已經為堆,無需調整 if (heap[low] >= heap[j]) { return; } heap[i] = heap[j]; heap[j] = temp; // 調整之后,[j, high] 可能不滿足堆了,需繼續調整 adjust_heap(heap, j, high); #endif } // 只有一個結點的樹是堆,而在完全二叉樹中,所有序號 i > n/2 的結點都是葉子, // 因此以這些結點為根的子樹均已是堆。這樣,我們只需依次將以序號為 // n/2, n/2 - 1, …, 0 的結點作為根的子樹都調整為堆即可。 void build_heap(int* heap, int length) { assert(heap && length >= 0); int i; for(i = length / 2; i >= 0; --i) { adjust_heap(heap, i, length - 1); } } // 堆排序 // void heap_sort(int* array, int length) { assert(array && length >= 0); if (length <= 1) { return; } int i, temp; // 將 [0, length - 1] 建成初始堆 build_heap(array, length); // 對當前無序區 [0, i - 1] 進行堆排序,共做 length - 1 趟。 for(i = length - 1; i > 0; --i) { // 將堆頂和堆中最后一個記錄交換 temp = array[0]; array[0] = array[i]; array[i]= temp; // 將 [0, i - 1] 重新調整為堆,僅有 [0] 可能違反堆性質 adjust_heap(array, 0, i - 1); } }

時間復雜度分析:

 

堆排序的時間開銷主要由建立初始堆和反復調整堆這兩部分的時間開銷構成,你可以想象成二叉樹的情形。堆排序的平均時間復雜度為O(nlgn)。


空間復雜度分析:

很明顯,為 0(1)。


補充:

堆排序是不穩定的就地排序。


=======================================================================================

測試:

在前文《排序算法之插入排序》測試代碼的基礎上添加兩行代碼即可:

SortFucntionInfo sort_function_list[] = {

{"直接選擇排序", select_sort},

{"堆排序", heap_sort},

{"", NULL}

};


運行結果:

=== 直接選擇排序 ===

 original: 65 32 49 10 8 72 27 42 18 58 91

   sorted: 65 8 10 18 27 32 42 49 58 72 91


 original: 10 9 8 7 6 5 4 3 2 1 0

   sorted: 10 0 1 2 3 4 5 6 7 8 9



=== 堆排序 ===

 original: 65 32 49 10 8 72 27 42 18 58 91

   sorted: 8 10 18 27 32 42 49 58 65 72 91


 original: 10 9 8 7 6 5 4 3 2 1 0

   sorted: 0 1 2 3 4 5 6 7 8 9 10

 

posted on 2011-03-09 21:37 羅朝輝 閱讀(1482) 評論(0)  編輯 收藏 引用 所屬分類: Algorithms
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人免费网站| 好看的亚洲午夜视频在线| 亚洲第一视频网站| 亚洲在线中文字幕| 亚洲一区二区不卡免费| 国产精品99久久久久久www| 亚洲视频在线观看| 久久成人综合视频| 麻豆91精品91久久久的内涵| 欧美激情精品久久久久久变态 | 在线欧美日韩精品| 在线日韩日本国产亚洲| 亚洲精品老司机| 午夜精品亚洲一区二区三区嫩草| 欧美日韩国产综合视频在线| 亚洲一区二区三区视频播放| 亚洲欧美综合v| 久久免费观看视频| 亚洲国产婷婷香蕉久久久久久99| 夜夜爽99久久国产综合精品女不卡| 亚洲永久免费观看| 麻豆成人在线| 国产精品爽爽ⅴa在线观看| 国内偷自视频区视频综合| 亚洲国产精品t66y| 香蕉久久久久久久av网站| 欧美成人一区二区在线| 亚洲综合日韩在线| 欧美电影免费| 狠狠入ady亚洲精品经典电影| 一本色道久久88精品综合| 久久久久久网址| 日韩一区二区久久| 欧美大片一区二区三区| 国产欧美亚洲视频| 正在播放欧美一区| 欧美国产精品人人做人人爱| 午夜精品久久久久久久久久久| 免费欧美电影| 激情婷婷亚洲| 久久久国产精品一区二区中文| 日韩视频在线免费| 美女主播视频一区| 精品福利免费观看| 欧美伊人久久| 亚洲一二三四区| 国产精品超碰97尤物18| 亚洲美女尤物影院| 亚洲高清自拍| 麻豆成人av| 亚洲国产日韩欧美在线99| 久久久www免费人成黑人精品 | 久久国产精品久久久| 欧美三级午夜理伦三级中视频| 亚洲精美视频| 亚洲电影免费观看高清| 久久综合网hezyo| 伊人久久大香线蕉av超碰演员| 欧美中文日韩| 久久不射中文字幕| 合欧美一区二区三区| 久久精品久久99精品久久| 亚洲欧美一区二区三区在线| 国产精品亚洲综合色区韩国| 午夜天堂精品久久久久| 亚洲在线视频网站| 国产日韩欧美亚洲一区| 久久久久一区| 久热精品视频在线观看一区| 亚洲国产精品久久久久久女王| 欧美国产精品劲爆| 欧美片第1页综合| 国产农村妇女精品| 国产精品揄拍500视频| 亚洲欧美日韩国产中文在线| 在线一区观看| 国产精品一页| 久久人人超碰| 蜜桃av综合| 制服丝袜亚洲播放| 亚洲欧美日韩专区| 亚洲第一级黄色片| 99re热精品| 国产一区二区av| 亚洲电影激情视频网站| 国产精品videosex极品| 久久久久青草大香线综合精品| 麻豆91精品| 午夜欧美大片免费观看| 久久久久久亚洲精品杨幂换脸| 亚洲精品乱码久久久久久| 国产精品99久久99久久久二8| 韩国在线一区| 艳妇臀荡乳欲伦亚洲一区| 国产日韩av在线播放| 亚洲国产经典视频| 国产老女人精品毛片久久| 欧美成人免费va影院高清| 欧美午夜精品久久久久久超碰| 久久琪琪电影院| 欧美欧美在线| 男男成人高潮片免费网站| 欧美日韩午夜精品| 久久午夜精品一区二区| 欧美日韩一级片在线观看| 鲁大师成人一区二区三区| 欧美日韩直播| 欧美激情在线播放| 国产偷久久久精品专区| 99人久久精品视频最新地址| 亚洲国产精品va在看黑人| 欧美一级大片在线观看| 亚洲影院色无极综合| 欧美电影免费观看高清| 噜噜噜久久亚洲精品国产品小说| 国产精品视频yy9299一区| 亚洲精品国精品久久99热| 1204国产成人精品视频| 欧美一区二区在线免费观看| 亚洲尤物精选| 欧美日韩中文字幕在线| 亚洲国产cao| 亚洲第一主播视频| 欧美在线一级va免费观看| 亚洲欧美日韩精品综合在线观看| 欧美精品综合| 亚洲欧洲精品成人久久奇米网 | 亚洲承认在线| 欧美一区在线视频| 欧美一区二区三区播放老司机 | 国产精品高潮在线| 亚洲欧洲在线免费| 亚洲精品一区二区三区不| 久久综合色播五月| 免费在线国产精品| 久久久久久久久久久久久9999| 亚洲激情女人| 六十路精品视频| 欧美电影在线免费观看网站| 精品成人一区二区| 久久精品国亚洲| 美女脱光内衣内裤视频久久影院| 好男人免费精品视频| 久久久噜噜噜久久中文字免| 另类天堂视频在线观看| 在线播放不卡| 欧美a级理论片| 亚洲美女av在线播放| 亚洲一区视频在线| 国产久一道中文一区| 久久精品亚洲一区二区三区浴池| 免费观看成人网| 日韩视频在线一区二区| 欧美视频官网| 欧美一区二区三区在| 女人色偷偷aa久久天堂| 亚洲九九精品| 国产精品亚洲产品| 久久久久久国产精品mv| 亚洲国内自拍| 亚洲欧美另类久久久精品2019| 国产一二精品视频| 蜜臀av国产精品久久久久| 亚洲精品欧美极品| 欧美一级视频| 亚洲欧洲一区二区在线播放 | 在线精品国精品国产尤物884a| 久久久久久噜噜噜久久久精品| 亚洲国产精品久久91精品| 亚洲无线观看| 一区二区三区我不卡| 欧美视频在线免费看| 欧美一级在线视频| 亚洲欧洲日产国产网站| 久久久久久午夜| 一区二区三区国产盗摄| 韩国av一区二区三区| 欧美日韩中文精品| 裸体歌舞表演一区二区| 亚洲在线视频免费观看| 亚洲高清在线观看一区| 久久精品国产亚洲a| 一本色道久久加勒比精品| 精品动漫3d一区二区三区免费| 国产精品99免费看| 免费成人av在线看| 欧美伊人久久久久久久久影院| 日韩一级免费| 亚洲国产岛国毛片在线| 久久理论片午夜琪琪电影网| 亚洲字幕在线观看| 亚洲日本欧美日韩高观看| 国内成人精品2018免费看| 欧美日韩午夜激情| 欧美福利在线| 久久久国产午夜精品| 午夜免费日韩视频| 亚洲午夜一级| 一区二区三区日韩精品| 亚洲乱码国产乱码精品精|