希爾排序Shell sort

來源:互聯網
上載者:User

標籤:希爾   插入排序   實現   情況   組成   code   var   數字   pre   

希爾排序Shell Sort是基於插入排序的一種改進,同樣分成兩部分,

第一部分,希爾排序介紹

第二部分,如何選取關鍵字,選取關鍵字是希爾排序的關鍵

第一塊希爾排序介紹

準備待排數組[6 2 4 1 5 9]

首先需要選取關鍵字,例如關鍵是3和1(第一步分成三組,第二步分成一組),那麼待排數組分成了以下三個虛擬組:

[6 1]一組

[2 5]二組

[4 9]三組

看仔細啊,不是臨近的兩個數字分組,而是3(分成了三組)的倍數的數字分成了一組,

就是每隔3個數取一個,每隔三個再取一個,這樣取出來的數字放到一組,

把它們當成一組,但不實際分組,只是當成一組來看,所以上邊的"組"實際上並不存在,只是為了說明分組關係

對以上三組分別進行插入排序變成下邊這樣

[1 6] [2 5] [4 9]

具體過程:

[6 1]6和1交換變成[1 6]

[2 5]2與5不動還是[2 5]

[4 9]4與9不動還是[4 9]

第一趟排序狀態示範:

待排數組:[6 2 4 1 5 9]

排後數組:[1 2 4 6 5 9]

第二趟關鍵字取的是1,即每隔一個取一個組成新數組,實際上就是只有一組啦,隔一取一就全部取出來了嘛

此時待排數組為:[1 2 4 6 5 9]

直接對它進行插入排序

還記得插入排序怎麼排不?複習一下

[1 2 4]都不用動,過程省略,到5的時候,將5取出,在前邊的有序數組裡找到適合它的位置插入,就是4後邊,6前邊

後邊的也不用改,所以排序完畢

順序輸出結果:[1 2 4 5 6 9]

第二塊希爾排序的關鍵是如何取關鍵字,因為其它內容與插入排序一樣

那麼如何選取關鍵字呢?就是分成三組,一組,這個分組的依據是什麼呢?為什麼不是二組,六組或者其它組嘞?

好的增量序列的共同特徵:

① 最後一個增量必須為1

② 應該盡量避免序列中的值(尤其是相鄰的值)互為倍數的情況

 

 

以下C#代碼實現僅供參考

        static void shell_sort(int[] unsorted, int len)        {            int group, i, j, temp;            for (group = len / 2; group > 0; group /= 2)            {                for (i = group; i < len; i++)                {                    for (j = i - group; j >= 0; j -= group)                    {                        if (unsorted[j] > unsorted[j + group])                        {                            temp = unsorted[j];                            unsorted[j] = unsorted[j + group];                            unsorted[j + group] = temp;                        }                    }                }            }        }        static void Main(string[] args)        {            int[] x = { 6, 2, 4, 1, 5, 9 };            shell_sort(x, x.Length);            foreach (var item in x)            {                Console.WriteLine(item);            }            Console.ReadLine();        }

希爾排序Shell sort

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.