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

羅朝輝(飄飄白云)

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

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

排序算法之選擇排序   

羅朝輝(http://www.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>
            亚洲第一中文字幕在线观看| 欧美一区二区三区久久精品| 蜜桃久久av一区| 久久美女性网| 日韩一级视频免费观看在线| 亚洲毛片播放| 国产精品久久7| 久久人人爽人人爽爽久久| 久久视频在线看| 一区二区三区精品国产| 亚洲一区二区三区免费视频| 国产亚洲观看| 亚洲日本免费| 国产日韩精品视频一区| 欧美成人性网| 国产精品蜜臀在线观看| 欧美成人按摩| 国产精品黄视频| 免费观看在线综合| 国产精品扒开腿做爽爽爽视频| 久久精品99国产精品日本| 欧美va天堂在线| 久久精品国产欧美激情| 欧美日本国产精品| 久久久99久久精品女同性| 欧美久久一区| 久久嫩草精品久久久精品一| 欧美日韩在线另类| 免费观看一级特黄欧美大片| 国产精品免费一区豆花| 91久久久久久| 精品动漫一区| 亚洲自拍偷拍一区| 99精品欧美| 久久综合色8888| 欧美综合国产精品久久丁香| 欧美人与性动交cc0o| 又紧又大又爽精品一区二区| 在线一区观看| 日韩亚洲成人av在线| 久久久久久久久一区二区| 亚洲一区二区三区免费视频| 欧美va天堂| 免费在线观看日韩欧美| 国内外成人免费激情在线视频| 99在线|亚洲一区二区| 亚洲精品久久嫩草网站秘色| 久久狠狠久久综合桃花| 午夜精品久久久久久久白皮肤| 欧美大片91| 亚洲国产精品传媒在线观看| 亚洲成人直播| 久久久久免费视频| 久久久.com| 免费久久99精品国产自| 国产一区日韩欧美| 欧美在线观看视频在线| 欧美一区二区啪啪| 国产日产欧产精品推荐色 | 国产精品久久久久久久久免费| 亚洲国产一区二区三区在线播 | 欧美日韩亚洲另类| 亚洲人成人77777线观看| 91久久精品一区| 欧美激情a∨在线视频播放| 亚洲人成网站999久久久综合| 亚洲精品免费一二三区| 欧美日韩播放| 夜夜嗨一区二区| 亚洲欧美另类中文字幕| 国产美女高潮久久白浆| 久久精品国产精品亚洲| 欧美成人福利视频| 亚洲毛片在线看| 欧美三区美女| 午夜视频一区二区| 久久一区亚洲| 亚洲精品久久7777| 欧美三级视频在线| 欧美亚洲综合网| 欧美成人精品不卡视频在线观看| 亚洲精品久久久久久下一站 | 国产精品区免费视频| 亚洲综合国产精品| 久久婷婷国产综合国色天香| 亚洲人成网在线播放| 欧美网站在线| 久久午夜精品一区二区| 亚洲精品网站在线播放gif| 亚洲欧美一区二区激情| 激情自拍一区| 欧美日韩精品一二三区| 久久精品日韩一区二区三区| 亚洲国产成人在线播放| 午夜免费电影一区在线观看| 在线观看国产日韩| 国产精品www.| 欧美成人嫩草网站| 亚洲欧美精品在线| 亚洲美女一区| 国产亚洲欧美一区在线观看| 麻豆精品在线视频| 亚洲欧美色婷婷| 亚洲高清免费视频| 久久精品人人| 亚洲色无码播放| 在线免费不卡视频| 国产欧美精品久久| 欧美日韩小视频| 免费在线成人| 久久岛国电影| 午夜精品999| 亚洲精品国产精品国产自| 久久久之久亚州精品露出| 亚洲视频免费看| 亚洲人成网站999久久久综合| 国产亚洲制服色| 国产精品一区毛片| 欧美日本中文| 欧美精品福利视频| 免费看的黄色欧美网站| 久久久久久尹人网香蕉| 欧美一区激情视频在线观看| 夜久久久久久| 亚洲麻豆av| 亚洲国产精品免费| 欧美激情一区二区三区高清视频 | 91久久国产精品91久久性色| 久久先锋资源| 久久精品天堂| 久久黄色影院| 久久精品国产精品亚洲精品| 午夜精品视频在线| 亚洲与欧洲av电影| 亚洲一区二区成人| 一本色道久久综合亚洲91| 91久久精品日日躁夜夜躁国产| 亚洲成人在线视频网站| 亚洲国产美国国产综合一区二区| 韩国一区电影| 在线精品在线| 亚洲人成亚洲人成在线观看| 亚洲黄色在线观看| 亚洲人成精品久久久久| 一区二区高清视频| 亚洲午夜电影在线观看| 午夜国产精品影院在线观看| 欧美在线亚洲综合一区| 欧美中文字幕久久| 久久综合999| 亚洲国产91精品在线观看| 最新69国产成人精品视频免费| 亚洲精品一二区| 亚洲午夜一区| 欧美伊人久久久久久午夜久久久久| 亚洲欧美日韩国产成人精品影院 | 亚洲视频在线看| 欧美一级电影久久| 久久色在线播放| 欧美精品亚洲精品| 国产欧美三级| 亚洲国产精品成人综合色在线婷婷| 亚洲人成网站在线观看播放| 亚洲一区三区电影在线观看| 欧美在线一级va免费观看| 老司机免费视频一区二区三区| 欧美福利视频| 亚洲一区精彩视频| 久久gogo国模裸体人体| 欧美成人dvd在线视频| 国产精品视频免费观看| 亚洲高清色综合| 亚洲欧美一区二区三区极速播放| 蜜桃久久精品乱码一区二区| 99热免费精品在线观看| 久久精品国产免费| 国产伦精品一区二区三区| 国产精品草莓在线免费观看| 国产一区二区日韩精品| 亚洲九九精品| 久久露脸国产精品| 9国产精品视频| 久久色在线播放| 国产精品免费久久久久久| 亚洲成人在线| 欧美一区高清| 亚洲精品国产系列| 欧美永久精品| 国产精品久久久久久久久久尿| 影音欧美亚洲| 欧美亚洲一区在线| 999亚洲国产精| 免费在线日韩av| 国语自产精品视频在线看抢先版结局 | 91久久线看在观草草青青| 欧美在线黄色| 国产精品欧美经典| 在线综合+亚洲+欧美中文字幕| 欧美夫妇交换俱乐部在线观看| 欧美一区二区三区免费大片|