亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

八大排序算法詳解——希爾排序

2019-11-10 17:18:41
字體:
來源:轉載
供稿:網友

基本思想

先取一個小于n的整數d1作為第一個增量,把待排序的全部記錄分成dx個組。所有距離為d1的倍數的記錄放在同一個組中。先在各組內進行直接插人排序。然后,取第二個增量d2<d1重復上述的分組和排序。直至所取的增量dt=1(dt<dt-x<…<d2<d1),即所有記錄放在同一組中進行直接插入排序為止。

算法實現

希爾排序算法,java實現,代碼如下所示:

public abstract class Sorter { public abstract void sort(int[] array); } public class ShellSorter extends Sorter { @Override public void sort(int[] array) { int d = array.length; do { d /= 2; shellPass(array, d); // 根據逐漸減小的間隔增量,循環調用一趟排序 } while (d > 1); } /** * 希爾一趟排序 * @param d 間隔增量 */ PRivate void shellPass(int[] array, int d) { Integer tmp; for (int i = d; i < array.length; i++) { // 數組下標從0開始,初始i=d表示一趟排序中第二個元素 tmp = array[i]; // array[i]的拷貝 // 如果待處理的無序區第一個元素array[i] < 有序區最大的元素array[i-d] // 需要將有序區比array[i]大的元素向后移動 if (array[i] < array[i - d]) { int j = i - d; while (j >= 0 && tmp < array[j]) { array[j + d] = array[j]; // 將左側有序區中元素比array[i]大的array[j+d]后移 j -= d; } // 如果array[i] >= 左側有序區最大的array[i-d],或者經過掃描移動后,找到一個比array[i]小的元素 // 將右側無序區第一個元素tmp = array[i]放到正確的位置上 array[j + d] = tmp; } } } }

排序過程

希爾排序的過程如下:

首先初始化間隔d為待排序數組的長度,無需排序。減小d,對于每次得到的間隔d,執行多組排序,使得原始數組間隔為d的一個子數組為有序,該數組通過類似直接插入排序的算法來執行排序。直到,d減小為1的時候,整個數組為有序。這里,采用二分的策略來得到間隔d。

下面通過例子來說明,執行希爾排序的過程,如下所示:假設待排序數組為array = {94,12,34,76,26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49},數組大小為20。整個排序過程的分組情況,如下所示:

1{94,12,34,76,26,9,0,37,55,76,37,5,68,83,90,37,12,65,76,49}
2{37,5,34,76,26,9,0,37,55,49,    94,12,68,83,90,37,12,65,76,76}
3{9,0,34,55,26,    37,5,37,76,49,    37,12,65,76,76,    94,12,68,83,90}
4{5,0,    9,12,12,    37,26,    37,34,49,    37,55,    65,68,76,    76,76,    90,83,94}
5{0,    5,    9,    12,12,    26,    34,    37,    37,37,    49,    55,    65,    68,76,    76,    76,    83,    90,94}

下面說明詳細過程:首先,初始化d = 20。在循環中反復得到間隔d,根據d執行一趟希爾排序。

對于d = 20/2 = 10:

根據d = 10來對數組排序,將原始數組分成2塊: {94,12,34,76,26,9,0,37,55,76}與{37,5,68,83,90,37,12,65,76,49},也就是對如下數組分別進行直接插入排序:{array[0],array[10]} = {94,37}{array[1],array[11]} = {12,5}{array[2],array[12]} = {34,68}{array[3],array[13]} = {76,83}{array[4],array[14]} = {26,90}{array[5],array[15]} = {9,37}{array[6],array[16]} = {0,12}{array[7],array[17]} = {37,65}{array[8],array[18]} = {55,76}{array[9],array[19]} = {76,49}第一趟希爾排序后,各個子數組變為:{37,5,34,76,26,9,0,37,55,49}與{94,12,68,83,90,37,12,65,76,76},即:array = {37,5,34,76,26,9,0,37,55,49,94,12,68,83,90,37,12,65,76,76},

對于d = 10/2 = 5:

根據d = 5來對數組排序,將第一趟希爾排序后的數組分成4塊 :{37,5,34,76,26}、{9,0,37,55,49}、{94,12,68,83,90}與{37,12,65,76,76},也就是對如下數組分別進行直接插入排序:{array[0],array[5],array[10],array[15]} = {37,9,94,37}{array[1],array[6],array[11],array[16]} = {5,0,12,12}{array[2],array[7],array[12],array[17]} = {34,37,68,65}{array[3],array[8],array[13],array[18]} = {76,55,83,76}{array[4],array[9],array[14],array[19]} = {26,49,90,76}第二趟希爾排序后,各個子數組變為:{9,0,34,55,26}、{37,5,37,76,49}、{37,12,65,76,76}與{94,12,68,83,90},即:array = {9,0,34,55,26,37,5,37,76,49,37,12,65,76,76,94,12,68,83,90}。

對于d = 5/2 = 2:

根據d = 2來對數組排序,將第二趟希爾排序后的數組分成10塊: {9,0}、{34,55}、{26,37}、{5,37}、{76,49}、{37,12}、{65,76}、{76,94}、{12,68}與{83,90},也就是對如下數組分別進行直接插入排序:{array[0],array[2],array[4],array[6],array[8],array[10],array[12],array[14],array[16],array[18]} = {9,34,26,5,76,37,65,76,12,83}{array[1],array[3],array[5],array[7],array[9],array[11],array[13],array[15],array[17],array[19]} = {0,55,37,37,49,12,76,94,68,90}第三趟希爾排序后,各個子數組變為:{5,0}、{9,12}、{12,37}、{26,37}、{34,49}、{37,55}、{65,68}、{76,76}、{76,90}與{83,94},即:array = :{5,0,9,12,12,37,26,37,34,49,37,55,65,68,76,76,76,90,83,94}。

對于d = 2/2 = 1:

根據d = 1來對數組排序,將第二趟希爾排序后的數組分成20塊:{5}、{0}、{9}、{12}、{12}、{37}、{26}、{37}、{34}、{49}、{37}、{55}、{65}、{68}、{76}、{76}、{76}、{90}、{83}、{94},也就是對如下數組分別進行直接插入排序:{5,0,9,12,12,37,26,37,34,49,37,55,65,68,76,76,76,90,83,94}第四趟希爾排序以后,數組已經有序:array = {0,5,9,12,12,26,34,37,37,37,49,55,65,68,76,76,76,83,90,94}。因為 d= 1,希爾排序結束。

算法分析

希爾排序是基于插入排序的一種算法, 它的時間復雜度與增量序列的選取有關,例如:

希爾提出了增量序列 h1 ,h2 ,……,ht ,只要h1=1,任何增量序列都是可行的,使用希爾增量排序的時間復雜度為O(n^2)。Hibbard提出了一個增量序列:2^k-1,使用Hibbard增量排序的時間復雜度為O(n^(3/2))。Sedgewick提出了幾種增量序列:9*4i – 9*2i +1 或者是 4i – 3* 2i + 1,最壞運行時間為O(n^(4/3)),對這些增量序列的平均運行時間猜測為O(n^(7/6))。

但是現今仍然沒有人能找出希爾排序的精確下界。希爾排序沒有快速排序算法快O(nlogn),因此中等大小規模表現良好,對規模非常大的數據排序不是最優選擇。但是比O(n^2)復雜度的算法快得多。此外,希爾算法在最壞的情況下和平均情況下執行效率相差不是很多,與此同時快速排序在最壞的情況下執行的效率會非常差。專家們提倡,幾乎任何排序工作在開始時都可以用希爾排序,若在實際使用中證明它不夠快,再改成快速排序這樣更高級的排序算法。本質上講,希爾排序算法是直接插入排序算法的一種改進,減少了其復制的次數,速度要快很多,原因是,當n值很大時數據項每一趟排序需要的個數很少,但數據項的距離很長。當n值減小時每一趟需要和動的數據增多,此時已經接近于它們排序后的最終位置。 正是這兩種情況的結合才使希爾排序效率比插入排序高很多。

時間復雜度

希爾排序的效率很大程度上依賴于增量序列的選擇,好的增量序列有如下共同特征:

最后一個增量必須為1。應該盡量避免序列中的值(尤其是相鄰的值)互為倍數的情況。

有人通過大量的實驗,給出了較好的結果:當n較大時,比較和移動的次數約在n^1.25到1.6*n^1.25之間。另外,希爾排序的時間性能優于直接插入排序,原因是:

當文件初態基本有序時直接插入排序所需的比較和移動次數均較少。當n值較小時,n和的差別也較小,即直接插入排序的最好時間復雜度O(n)和最壞時間復雜度0()差別不大。在希爾排序開始時增量較大,分組較多,每組的記錄數目少,故各組內直接插入較快,后來增量di逐漸縮小,分組數逐漸減少,而各組的記錄數目逐漸增多,但由于已經按di-1作為距離排過序,使文件較接近于有序狀態,所以新的一趟排序過程也較快。

因此,希爾排序在效率上較直接插入排序有較大的改進。

空間復雜度

因為希爾排序依賴于增量序列,從而導致排序的趟數不固定,對于不同的增量執行一趟希爾排序,只用到一個輔助變量,所以空間復雜度為O(n)。

排序穩定性

由于多次插入排序,我們知道一次插入排序是穩定的,不會改變相同元素的相對順序,但在不同的插入排序過程中,相同的元素可能在各自的插入排序中移動,最后其穩定性就會被打亂,通過上述元素76可以看到,希爾排序不穩定。

因此,希爾排序是不穩定的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区三区视频免费| 亚洲色图日韩av| 国产亚洲精品美女久久久| 国产91久久婷婷一区二区| 久久久欧美一区二区| 岛国精品视频在线播放| 国产不卡av在线免费观看| 不卡伊人av在线播放| 欧美在线一区二区三区四| 91手机视频在线观看| 日韩电影网在线| 欧美噜噜久久久xxx| 国语自产精品视频在线看抢先版图片| 久久手机精品视频| 55夜色66夜色国产精品视频| 九九九久久国产免费| 69**夜色精品国产69乱| 欧美午夜影院在线视频| 91av在线视频观看| 色偷偷88888欧美精品久久久| 中文字幕视频一区二区在线有码| 亚洲国产第一页| 亚洲网址你懂得| 丰满岳妇乱一区二区三区| 欧美日韩电影在线观看| 国产精品老女人精品视频| 国产手机视频精品| 亚洲日韩欧美视频一区| 欧美日韩成人在线观看| 日韩精品中文字幕视频在线| 国产精品女人久久久久久| 国产成人精品日本亚洲| 日韩精品极品视频免费观看| 久久综合久久美利坚合众国| 美日韩丰满少妇在线观看| 色小说视频一区| 一区二区成人精品| 中文字幕亚洲欧美日韩2019| 久久99精品久久久久久青青91| 中文字幕av一区二区三区谷原希美| 日韩免费视频在线观看| www.欧美三级电影.com| 久久久久在线观看| 亚洲qvod图片区电影| 日韩在线一区二区三区免费视频| 一本色道久久88综合亚洲精品ⅰ| 国产亚洲精品一区二555| 欧美影院久久久| 亚洲欧美另类人妖| 久久不射热爱视频精品| 国产精品第8页| 久久成人精品电影| 久久久www成人免费精品张筱雨| 久久99久国产精品黄毛片入口| 8050国产精品久久久久久| 久久久免费高清电视剧观看| 国产精品观看在线亚洲人成网| 久久久久久尹人网香蕉| 色偷偷91综合久久噜噜| 久久久久久亚洲精品中文字幕| 久久久亚洲影院你懂的| 精品美女永久免费视频| 久久天天躁狠狠躁夜夜av| 欧美另类极品videosbest最新版本| 久久久久99精品久久久久| 日韩在线视频观看正片免费网站| 成人久久18免费网站图片| 97在线精品国自产拍中文| 国产欧美日韩视频| 国产欧美精品在线播放| 久久久久久久一区二区三区| 亚洲jizzjizz日本少妇| 中文字幕欧美日韩在线| 日韩亚洲欧美中文在线| 中文字幕亚洲精品| 精品日韩美女的视频高清| 91夜夜未满十八勿入爽爽影院| 欧美黑人一区二区三区| 亚洲精品99久久久久| 欧美日韩在线免费观看| 91精品国产91| 日韩精品在线观看网站| 欧美在线播放视频| 97在线视频国产| 欧洲午夜精品久久久| 欧美激情免费看| 在线播放国产一区中文字幕剧情欧美| 在线观看国产精品91| 国产精品稀缺呦系列在线| 国产亚洲精品va在线观看| 亚洲国产私拍精品国模在线观看| 国产精品igao视频| www.日韩av.com| 国产亚洲视频在线观看| 国产99视频在线观看| 国模吧一区二区| 岛国视频午夜一区免费在线观看| 日韩有码片在线观看| 日韩中文第一页| 欧美高清在线播放| 欧美成人一二三| 在线播放日韩精品| 欧美成人三级视频网站| 91福利视频网| 亚洲精品国产综合区久久久久久久| 最近的2019中文字幕免费一页| 亚洲午夜久久久影院| 欧美国产日韩在线| 日本在线观看天堂男亚洲| 欧美高清视频免费观看| 亚洲欧美在线免费观看| 国产精品黄色av| 国产不卡在线观看| 亚洲男人天堂网站| 欧日韩不卡在线视频| 精品国产欧美一区二区三区成人| 欧美剧在线观看| 69国产精品成人在线播放| 日韩av在线免费| 欧美中文在线观看| 日韩欧美国产免费播放| 国产精品日韩在线一区| 欧美成人午夜视频| 97精品一区二区三区| 精品国内产的精品视频在线观看| 91精品国产乱码久久久久久久久| 视频在线观看一区二区| 欧美精品福利视频| 97**国产露脸精品国产| 插插插亚洲综合网| 国内精品免费午夜毛片| 2019中文字幕免费视频| 久久久久99精品久久久久| 国产欧美精品一区二区三区-老狼| 久久亚洲综合国产精品99麻豆精品福利| 亚洲美女av在线播放| 欧美另类老女人| 欧美中文字幕在线观看| 亚洲欧美自拍一区| 国产精品永久免费| 亚洲精品99久久久久| 一二美女精品欧洲| 夜色77av精品影院| 亚洲第一免费网站| 国产精品丝袜久久久久久不卡| 久久久99免费视频| 国产日韩欧美一二三区| 亚洲老司机av| 97成人精品区在线播放| 日韩中文字幕视频在线| 欧美日韩成人黄色| 欧美成人免费网| 精品中文字幕视频| 久久男人av资源网站| 欧美极度另类性三渗透| 日韩中文字幕网| 国内自拍欧美激情| 日韩国产精品亚洲а∨天堂免| 欧美三级免费观看| 亚洲福利精品在线| 91国产高清在线| 欧美www视频在线观看| 精品毛片网大全| 久久久久久久久久久成人|