C++深入淺出講解希爾排序算法的實(shí)現(xiàn)
插入排序分為兩種:直接插入排序&希爾排序
希爾排序
1.基本思想
希爾排序是在直接插入排序基礎(chǔ)上的優(yōu)化,屬于非常牛掰的一個(gè)排序。
核心思想:
- 先進(jìn)行預(yù)排序,讓數(shù)組接近有序;
- 直接插入排序
預(yù)排序
預(yù)排序步驟:
分組排,假設(shè)gap==3,間隔為gap的為一組,然后分別使用插入排序的思想對(duì)這gap組數(shù)據(jù)進(jìn)行排序

多組間隔為gap的預(yù)排序,gap由大變小,gap越大,大的數(shù)可以越快的到后面,小的數(shù)可以越快得到前面,gap越大,預(yù)排完越不接近有序,gap越小,預(yù)排完越接近有序,gap為1時(shí)就是直接插入排序
動(dòng)圖演示:

預(yù)排序代碼:
for (int i = 0; i < gap; i++)//有g(shù)ap組需要排
{
for (int j = i; j < n - gap; j += gap)//內(nèi)層循環(huán),先排紅,再排綠,最后排藍(lán)
//注意內(nèi)層循環(huán)的寫法
{
//跟直接插入排序很像,不同的是需要使用gap
int end = j;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
}
這是最初的寫法,其實(shí)這個(gè)代碼是可以優(yōu)化的:
//預(yù)排序優(yōu)化
for (int i = 0; i < n - gap; i++)
//把間隔為gap的多組數(shù)據(jù)同時(shí)排
//當(dāng)?shù)絥-gap-1的位置就終止了
{
int end = i;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
2.算法實(shí)現(xiàn)
//希爾排序
void ShellSort(int* a, int n)
{
//一開始初始化gap為n
int gap = n;
while (gap > 1)//gap大于1都是預(yù)排序,gap==1時(shí)為直接插入排序
{
//為保證gap最終結(jié)果為1,可以gap/=2,也可以是gap=gap/3+1;
gap /= 2;
//預(yù)排序優(yōu)化
for (int i = 0; i < n - gap; i++)
//把間隔為gap的多組數(shù)據(jù)同時(shí)排
//當(dāng)?shù)絥-gap-1的位置就終止了
{
int end = i;
int tmp = a[end + gap];
while (end >= 0)
{
if (a[end] > tmp)
{
a[end + gap] = a[end];
end -= gap;
}
else
{
break;
}
}
a[end + gap] = tmp;
}
}
}
完整代碼:

3.時(shí)間復(fù)雜度
希爾排序的時(shí)間復(fù)雜度是:O(N*logN)

到此這篇關(guān)于C++深入淺出講解希爾排序算法的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)C++希爾排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Ubuntu配置sublime text 3的c編譯環(huán)境的具體步驟
下面小編就為大家?guī)硪黄猆buntu配置sublime text 3的c編譯環(huán)境的具體步驟。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
C++標(biāo)準(zhǔn)庫中sstream與strstream的區(qū)別詳細(xì)解析
以下是對(duì)C++標(biāo)準(zhǔn)庫中sstream與strstream的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-09-09
C++面試八股文之STL標(biāo)準(zhǔn)模板庫使用詳解
這篇文章主要為大家介紹了C++面試八股文之STL標(biāo)準(zhǔn)模板庫使用詳解,<BR>有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
c++實(shí)現(xiàn)單純形法現(xiàn)行規(guī)劃問題的求解(推薦)
這篇文章主要介紹了c++實(shí)現(xiàn)單純形法現(xiàn)行規(guī)劃問題的求解,本文針對(duì)問題通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04

